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PHP 是 比较 普及 的 互联 网 开发 语言 之 一 。 本 书 按 新 手 从 入 门 到 精通 的 
学 习 过 程 ， 从 实际 的 应 用 出 发 详细 介绍 了 PHP 的 脚本 语言 基础 、 开 发 运行 
环境 以 及 各 种 常用 动态 功能 系统 的 开发 。 全 书 共 10 章 ， 内 容 分 为 理论 部 分 
和 实战 部 分 ， 由 浅 入 深 地 介绍 了 PHP 以 及 相关 技术 ， 通 过 大 量 实际 项 目的 
案例 ， 详 尽 地 讲解 了 PHP 的 技术 要 点 和 开发 过 程 ， 精 选 动态 功能 模块 实 
例 ， 通 过 实例 的 讲解 来 让 读者 理解 PHP+MySQL 的 动态 开发 方法 。 全 书包 
括 用 户 管理 系统 、 新 闻 发 布 系统 、 留 言 板 管理 系统 、 投 票 管理 系统 、BBS 
论坛 管理 系统 和 网 上 购物 系统 等 6 PRERA 

本 书 内 容 丰 富 ， 实 用 性 和 操作 性 强 ， 适 合 学 习 PHP-MySQL-Dream- 
weaver 动态 网 页 制作 的 初级 读者 ， 也 适合 作为 高 等 院 校 本 、 专 科 各 专业 动态 
网 页 制作 课程 的 教材 ， 还 可 以 作为 网 页 设计 与 制作 爱好 者 的 自学 参考 书 。 


图 书 在 版 编目 《CIP) 数据 


PHP+MySQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 / Bas rd; MP 
博文 化 组 编 . 一 北京 : 机 械 工 业 出 版 社 ，2012.2 (2016.1 重 印 ) 
《金牌 网 站 设计 师 系列 从 书 ) 

ISBN 978-7-111-37947-8 

I. QP-- II. 四 陈 …@ 环 … DIL OPHP 语言 一 程序 设计 @ 关 系数 
据 库 一 数据 库 管 理 系统 ，MySQLG) 主 页 制作 一 图 形 软 件 ，Dreamweaver 
IV. (CDOTP312COTP311.138GOITP393.092 

















中 国 版 本 图 书馆 CIP 数据 核 字 (2012) 第 059895 5 





机 械 工 业 出 版 社 (北京 市 百 万 庄 大 街 22 号 ”邮政 编码 100037) 
策划 编辑 : J wk 。” 责任 编辑 ] W: 





FKE TE P ERLEA BRAE) ENA 


2016 4E. 1 HÆ 1 版。 第 7 次 印刷 
184mm X 260mm * 28 印张 。690 FÆ 
16601— 18500 Jl] 


标准 书号 : ISBN 978-7-111-37947-8 





ISBN 978-7-89433-466-4 (光盘 ) 


定价 : 69.80 元 ( 含 1DVD) 








凡 购 本 书 ， 如 有 缺 页 、 倒 页 、 脱 页 ， 由 本 社 发 行 部 调换 
电话 服务 网 络 服务 

社 服 务 中 心 : (010) 88361066 
销售 一 部 : (010) 68326294 
销售 二 部 :(010) 88379649 教材 网 : http://www.cmpedu.com 


读者 购书 热线 : (010) 88379203 封面 无 防伪 标 均 为 盗版 


门户 网 : http:Wwww.cmpbook.com 


z= 
Tii 





——— 


RU E 


PHP 是 最 为 流行 的 Web 编程 语言 之 一 ， 具 有 开源 和 免费 的 独特 优势 。MySQL 是 一 个 广 
受 欢 迎 的 中 型 关系 数据 库 管 理 系统 ， 它 免费 、 快 速 、 跨 平台， 并 且 文 持 多 线程 、 多 用 户 、 重 
负载 的 性 能 要 求 。 使 用 PHP+MySQL 进行 Web 应 用 系统 开发 是 一 种 非常 理想 的 选择 。 

与 其 他 相 类 似 的 计算 机 图 书 相 比 ， 本 书 具 有 以 下 几 点 特色 : 

Dw 内 容 选 编 售 明 扼 要 

一 般 的 PHP 书籍 会 介绍 很 多 的 理论 知识 ， 但 本 书 选 编 内 容 人 简明 扼 要 ， 适 合 初 学 者 学 习 
使 用 。 介 绍 PHP+MySQL 的 基础 知识 时 ， 利 用 每 一 布 介绍 一 个 知识 点 并 同步 配 以 实例 加 以 理 
解 应 用 。 全 书 主题 鲜明 、 要 点 明确 ， 介 绍 了 制作 网 页 的 技巧 和 规范 ， 可 以 让 读者 快速 学 会 使 
用 Dreamweaver CS4 按照 网 页 规范 进行 网 页 制作 。 

ow 从 入 门 到 高 手 导 问 清 晰 

书 中 的 所 有 实例 均 出 自作 者 多 年 来 的 商业 应 用 实例 ， 如 果 是 初学 者 ， 认 真 学 习 第 1 一 3 
章 即 可 以 掌握 平台 的 搭建 、PHP 和 MySQL 配合 开发 的 基础 知识 。 第 4~6 mei 
Dreamweaver 的 集成 动态 功能 ， 快 速 掌 握 在 Dreamweaver 中 开发 PHP 动态 系统 的 功能 。 第 
7 一 10 FAJFI PHP 代码 实现 动态 系统 的 开发 ， 成 为 真正 的 PHP 网 页 开发 高 手 。 每 草 的 
实例 均 符 合 所 讲解 的 知识 点 ， 实 现 了 实践 与 理论 相 结 合 ， 对 于 读者 在 制作 中 的 思路 整理 、 开 
发 创意 会 有 所 帮助 。 

By 超 值 赠送 多 媒体 和 素材 光盘 

附送 光盘 中 制作 了 PHP 开发 平台 搭建 的 多 媒体 教学 光盘 ， 同 时 附 有 所 用 网 站 源 代码 及 
素材 ， 是 轻松 掌握 PHP 网 站 开发 的 最 佳 素材 宝典 。 

本 书 详细 介绍 了 PHP 和 MySQL 开发 的 基础 知识 、 技 术 要 点 ， 并 结合 PHP 和 MySQL 
前 述 了 动态 网 站 的 开发 方法 。 全 书 共 分 10 草 ， 各 草 的 详细 内 容 如 下 。 

第 1 草 介 绍 了 有 关 PHP-MySQL 开发 平台 搭建 的 知识 ， 评 细 说 明了 PHP 5.0 的 基础 知 
iM. Apache 服务 器 的 安装 与 配置 、PHP 环境 的 安装 与 配置 、MySQL 数据 库 的 安 钱 与 管理 以 
及 解决 数据 库 中 文 乱码 问题 等 内 容 。 

第 2 AIAS PHP 的 编程 基础 ， 这 是 使 用 Dreamweaver 开发 网 站 的 第 一 步 ， 介 绍 了 在 
Dreamweaver 进行 PHP 开发 平台 的 搭建 、PHP 程序 编写 的 基础 知识 ， 掌 握 PHP 表单 变量 的 
使 用 、PHP 程序 中 常量 、 变 量 、 表 达 式 以 及 函数 的 基础 ， 其 中 要 重点 掌握 PHP 和 MySQL Zt 
据 库 的 操作 。 

第 3 章 介 绍 了 在 Dreamweaver 软件 下 实现 动态 功能 的 开发 基础 操作 ， 重 点 介绍 了 
Dreamweaver 进行 PHP 开发 的 流程 ， 搭 建 PHP 动态 系统 开发 的 平台 ， 检 查 数 据 库 记 录 的 常 
见 操 作 和 编辑 记录 的 常见 操作 。 

第 4 章 介 绍 了 一 个 典型 的 用 户 管理 系统 ， 在 动态 网 站 中 ， 用 户 管理 系统 是 非常 必要 
的 。 通 过 用 户 注册 信息 的 统计 ， 可 以 让 管理 员 了 解 到 网 站 的 访问 情况 ， 通 过 用 户 权 限 的 设 
置 ， 可 以 限制 网 站 页 面 的 访问 权限 。 一 个 用 户 管理 系统 ， 一 般 应 该 具备 用 户 注册 功能 、 资 
料 修改 功能 、 取 回 密码 功能 以 及 用 户 注 销 身 份 等 功能 。 














































































































A PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 








第 5 章 着 重 介 绍 了 新 闻 发 布 系 统 的 实现 方法 。 新 闻 发 布 系统 是 动态 网 站 建设 中 经 常用 到 
的 系统 ， 尤 其 是 政府 单位 、 教 育 单位 或 企业 网 站 。 新 闻 发 布 系统 的 作用 就 是 在 网 上 传播 信 
县 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 行业 信息 、 企 业 状 况 。 所 以 新 闻 发 布 系统 中 涉 
及 的 主要 操作 就 是 访问 者 的 新 闻 查 询 功能 和 系统 管理 员 对 新 闻 的 新 增 、 人 修改、 删除 功能 ， 使 
用 PHP 实现 这 些 功能 相对 比较 简单 。 

第 6 章 介 绍 了 留言 板 管理 系统 的 制作 方法 。 留 言 板 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 
收集 用 户 意见 和 信息 ， 也 是 网 站 建设 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 析 ， 可 以 为 访问 人 
员 提 供 发 言 的 机 会 ， 让 他 们 及 时 、 准 确 地 发 表 目 己 的 观点 。 这 些 观点 被 保留 在 服务 器 上 的 数 
据 库 中 ， 而 且 可 以 被 任何 一 个 访问 站 点 的 人 看 到 。 

第 7 章 介 绍 了 投票 管理 系统 的 开发 方法 。 一 个 投票 管理 系统 大 体 可 分 为 3 个 模块 : Xe 
票 模 块 、 选 票 处 理 模 块 以 及 结果 显示 模块 。 投 票 管理 系统 首先 给 出 选票 选 题 ， 即 供 投 票 者 
选择 的 表单 对 象 ， 当 投票 者 单 击 选 择 投 票 按 钮 后 ， 选 票 处 理 模 块 激活 ， 对 服务 器 传送 过 来 的 
数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1 ， 然 后 对 数据 进行 
更 新 ， 最 后 将 结果 显示 出 来 。 

第 8 ANMAT BBS 论坛 管理 系统 的 开发 。 将 学 习 使 用 PHP 实现 BBS 论坛 的 开发 方 
ik. BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 版 块 ， 按 照 版 块 或 者 栏目 的 不 同 ， 可 以 由 管理 
员 设 立 不 同 的 版 主 ， 版 主 可 以 对 上 自己 的 栏目 或 版 块 进行 删除 、 修 改 或 者 锁定 等 操作 。 

第 9 章 制 作 了 一 个 电子 商务 网 站 的 表 台 开发 方法 。 主 要 介绍 使 用 PHP 进行 网 上 购物 系 
统 前 台 开 发 的 方法 ， 系 统 地 介绍 了 网 上 购物 系统 的 设计 。 数 据 库 的 规划 以 及 常用 的 儿 个 功能 
模块 前 人 台 的 开发 。 

第 10 章 介 绍 电子 商务 网 站 的 后 人 台 功 能 开发 方法 。 一 个 完善 的 网 上 购物 系统 并 不 只 是 提 
供给 用 户 注 册 、 进 行 购物 等 功能 。 它 还 要 给 网 站 所 有 者 一 个 功能 齐全 的 后 台 管 理 功能 。 网 
站 所 有 者 登录 后 台 管 理 即 可 发 布 新 公告 、 管 理会 员 注 册 、 回 复 留 言 、 维 护 商 品 ， 以 及 管理 
订单 。 

本 书 由 拥有 将 近 10 年 网 站 建设 实战 经 验 的 资深 设计 师 编写 ， 实 现 了 理论 、 实 践 相 结 
合 ， 章 节 安 排 合 理 ， 注 重 了 内 容 的 实用 性 、 可 操作 性 。 本 书 由 环 博 文化 的 陈 益 材 主 编 ， 另 有 
于 和 谷 云 、 官 斯 文 、 气 亮 、 王 炎 光 、 耿 国 续 、 陈 益 红 、 秦 树 德 、 张 铭 运 、 赵 红 、 陈 章 、 于 海 
饮 、 任 霖 参与 了 编写 工作 。 由 于 作者 水 平 有 限 ， 加 之 创作 时 间 仓 促 ， 本 书 疏 漏 之 处 在 所 难 
免 ， 欢 迎 各 位 谈 者 与 专家 批评 指正 。 
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第 四 目 音 ”搭建 PHP 网 站 建设 平台 


PHP 是 一 项 很 有 前 途 的 站 点 动态 网 页 技术 ， 有 是 最 普及 、 应 用 最 广泛 的 Web 开发 语言 之 一 ， 其 


独特 的 语法 混合 了 C Java, Per 以 及 PHP. 目 创 的 新 的 语法 。 它 具有 开放 的 源 代 码 和 多 种 数据 库 
的 文 持 ， 并 且 文 持 器 平台 的 操作 和 面 问 对 象 的 编程 ， 而 且 是 完全 免费 的 。 掌 氛 好 这 个 技术 的 开 友 
也 并 不 困难 。 在 学 习 实 际 的 网 页 程序 编写 之 前 ， 上 自 要 的 就 是 利用 目 己 的 操作 系统 搭建 一 个 适合 
PHP 开发 的 操作 平台 。 现 在 的 操作 系统 只 要 是 Windows XP, Windows 7 等 ， 从 操作 角度 上 来 说 ， 
在 这 几 个 操作 平台 搭建 PHP 只 需 使 用 Apache (或 者 IS 因特网 信息 服务 系统 ) 十 Dreamweaver 
-MySQL 即 可 以 配置 出 来 。 由 于 Windows XP 操作 系统 比较 普及 ， 本 章 束 将 讲解 如 何在 Windows 
XP 中 进行 PHP 操作 平台 的 配置 。 
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(—7 PHP 5.0 的 基础 知识 

© Apache 服务 器 的 安装 与 配置 
(7 PHP 环境 的 安装 与 配置 

C MySQL 数据 库 的 安装 与 管理 
O 解决 数据 库 中 文 乱码 问题 
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EB 
PHP 基 础 知识 


PHP 是 一 种 多 用 途 脚 本 语言 ， 尤 其 适合 于 Web 应 用 程序 开发 。 利 用 PHP 强大 的 扩展 
性 ， 可 以 在 服务 并 连接 Java 应 用 程序 ， 还 可 以 与 .NET 建立 有 效 的 沟通 其 全 更 广阔 的 扩展 ， 
从 而 可 以 建立 一 个 强大 的 环境 ， 以 充分 利用 现 有 的 和 其 他 技术 开发 的 人 资源。 同时， 开源 和 路 
平台 的 特性 使 得 使 用 PHP 架构 能 够 快速 、 融 效 地 开 肥 出 可 移植 的 、 跨 平台 的 、 上 共有 强大 功 
能 的 企业 级 Web 应 用 程序 。 


«LL PHP 5.0 特性 | 


PHP 是 超 文本 预 处 理 语言 (Hypertext Preprocessor) HJHX 43. Pr HTML PX 
的 语言 。 它 与 微软 的 ASP HU. SERERE MAI. WA HTML 文档 的 脚本 语言 ， 
语言 的 风格 又 类 似 于 C 语言 ， 现 在 被 很 多 的 网 站 编程 人 员 广 泛 地 应 用 。 

与 其 他 的 编程 语言 做 出 的 动态 页 面相 比 ，PHP 是 将 程序 仍 入 到 HTML 文档 中 去 执行 ， 
执行 效率 比 完全 生成 HTML 标记 的 CGI Zimt. 5l HTML 文档 的 脚本 语言 
JavaScript 相 比 ，PHP 在 服务 器 端 执行 ， 充 分 利用 了 服务 器 的 性 能 。PHP 执行 引擎 还 会 将 用 
户 经 党 访问 的 PHP 程序 驻 留 在 内 存 中 ， 其 他 用 户 再 一 次 访问 这 个 程序 时 就 不 需要 重新 编译 
程序 ， 只 要 直接 执行 内 存 中 的 代码 就 可 以 ， 这 也 是 PHP 高 效率 的 体现 之 一 。 图 1-1 所 示 为 
PHP 的 运行 模式 。PHP 还 具有 非常 强大 的 功能 ， 所 有 的 CGI 或 者 JavaScript 的 功能 PHP 都 
能 实现 ， 而 且 文 持 儿 乎 所 有 流行 的 数据 库 以 及 操作 系统 。 
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Apache 网 站 服务 器 MySQL 数 据 库 服务 器 
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图 1-1 PHP 运行 模式 





PHP 最 初 只 是 用 Pen 语言 编写 的 简单 的 程序 ， 用 来 统计 自己 网 站 的 访问 量 。 后 来 又 
用 C 语言 重新 编写， 增加 了 可 以 访问 数据 库 等 功能 ， 并 在 1995 年 发 布 了 PHP 1.0. 2004 
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*E 7 H 13 H PHP 5.0 正式 版 本 的 发 布 ， 标 志 着 一 个 全 新 的 PHP 时 代 的 到 来 。 它 的 核心 是 

第 二 代 Zend 引擎 ， 并 引入 了 对 全 新 的 PECL 模块 的 支持 。 在 不 断 更 新 的 同时 ，PHP 5.0 
依然 保留 了 对 旧 PHP 4.0 程序 的 兼容 。 随 着 MySQL 数据 库 的 发 展 ，PHP 5.0 还 绑 定 了 新 

的 MySQL 扩展 模块 ， 提 供 了 一 些 更 加 有 效 的 方法 和 实用 工具 用 于 处 理 数据 库 操作 。PHP O) 
5.0 添加 了 面 癌 对 象 的 PDO (PHP Data Objects) 模块 ， 提 供 了 男 外 一 种 数据 库 操作 的 方 

案 ， 统 一 数据 库 操 作 的 API. 537b, PHP 5.0 中 还 改进 了 创建 动态 图 片 的 功能 ， 目 前 能 够 
支持 多 种 图 片 格式 (如 PNG, GIF, TIF, JPEG 等 )。PHP 5.0 已 经 内 置 了 对 GD2 FERE 

持 ， 因 此 安装 GD2 库 〈 主 要 指 UNIX 系统 中 ) 也 不 再 是 件 难事 ， 这 使 得 处 理 图 像 十 分 简 
单 和 高 效 。 

PHP 5.0 还 增加 了 只 有 成 熟 的 编程 语言 体系 结构 中 才 有 的 一 些 特性 ， 如 下 面 列 出 的 这 
些 特性 。 

(1) 增加 的 面向 对 象 能 力 。PHP 5.0 的 最 大 特点 是 引入 了 面向 对 象 的 全 部 机 制 ， 并 且 保 
留 了 问 下 的 兼容 性 。 程 序 员 不 必 再 编写 缺乏 功能 性 的 类 ， 并 旦 能 够 以 多 种 方法 实现 类 的 保 
护 。 另 外 ， 在 对 象 的 集成 等 方面 也 不 再 存在 问题 。 使 用 PHP 5.0 引进 的 类 型 提示 和 异常 处 理 
机 制 ， 能 更 有 效 地 处 理 和 避免 错误 的 发 生 。PHP 5.0 增加 了 很 多 功能 ， 例 如 显 式 构造 函数 和 
析 构 函数 、 对 象 克 隆 、 类 抽象 、 变 量 作用 域 和 接口 等 。 

(2) try/catch 卉 第 处 理 。 从 PHP 5.0 开始 支持 寞 党 处理。 在 许多 语言 中 ， 如 C++、 Cf. 
Python 和 Java 等 ， 异 滑 处 理 长 期 以 来 一 直 都 是 错误 管理 方面 的 中 流 研 柱 ， 为 建立 标准 化 的 
错误 报告 逻辑 提供 了 一 种 绝 佳 的 方法 。 

(3) 字符 串 处 理 。 之 前 版 本 的 PHP 默认 将 字符 串 看 做 数组 ， 这 也 反映 了 PHP 原先 的 数 
据 类 型 观点 不 够 严密 。 这 种 策略 在 版 本 5.0 中 有 所 调整 ， 引 入 了 一 种 专门 的 字符 串 偏 移 量 
(offset) 语法 ， 而 之 前 的 方法 已 经 废弃 不 用 。 

(4) XML 和 Web 服务 支持 。 现 在 的 XML 支持 建立 在 libxml2 库 基 础 上 ， 并 引入 一 
个 很 新 并 且 非 常 有 前 途 的 扩展 包 来 解析 和 处 理 XML: SimpleXML。 此 外 ，PHP 5.0 还 支 
持 SOAP 扩展 。 

(5) 对 SQLite 的 内 置 文 持 。PHP 5.0 为 功能 强大 、 人 简洁 的 SQLite 数据 库 服务 器 
Chttp:/www.sglite.org) 提供 了 文 持 。 如 果 开 发 人 员 需 要 使 用 一 些 只 有 重量 级 数据 库 产 品 中 才 
有 的 特性 ， 同 时 不 希望 带 来 相应 的 管理 开销 ，SQLite 则 是 一 个 很 好 的 解决 方案 。 


| PHP 开 发 环境 


在 开始 学 习 PHP 之 前 ， 首 先 需要 配置 PHP 的 运行 环境 。PHP 的 运行 环境 需要 两 个 软件 
的 文 持 : 一 个 是 PHP 运行 的 Web 服务 器 Apache， 而 在 具体 安装 Apache 服务 器 之 前 首先 要 
在 运行 的 系统 上 安装 支持 Apache 服务 器 的 Java 2 SDK; 另 一 个 是 PHP 运行 时 需要 加 载 的 主 
要 软件 包 ， 该 软件 包 主 要 是 解释 执行 PHP 页 面 的 脚本 程序 ， 如 解释 PHP 页 面 的 函数 。 本 书 
主要 介绍 Windows 操作 系统 下 使 用 Apache+PHP 配置 环境 的 方法 。 

PHP 开发 运行 环境 的 需求 如 图 1-2 PTR. 
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第 一 步 : 安装 Apache 服 务 器 





qi b. 安装 配置 PHP 





第 三 步 : 安装 配置 MySQL 数 据 库 | 


第 四 步 ， 管理 数据 库 ， 解 诀 中 文 乱码 
图 1-2 PHP 环境 配置 步骤 





Apache 服 务 天 的 安 表 
































首先 就 是 PHP 网 页 所 需 的 网 站 服务 器 (Web Server) 软 件 Apache 的 安装 与 设 定 。Apache 
网 站 服务 器 的 主要 工作 在 于 编译 PHP 网 页 ， 并 回 传 编译 后 的 PHP 网 页 至 使 用 者 计算 机 的 浏 
Warko Xem YE Apache 的 方法 说 明 如 下 。 














' Apache 简 介 








HM PHP 发 布 之 后 ， 推 出 了 各 式 各 样 的 PHP 引擎 ， 最 为 经 典 的 配置 束 是 使 用 Apache 服务 
fro Apache 是 一 种 开源 的 HTTP 服务 器 软件 ， 可 以 在 包括 UNIX. Linux 以 及 Windows 在 内 的 
大 多 数 主 流 计 算 机 操作 系统 中 运行 ， 由 于 其 文 持 多 平台 并 具有 民 好 的 安全 性 而 被 广泛 使 用 。 

Apache 作为 常 驻 的 后 台 任 务 运行 ， 在 UNIX 系统 中 为 守候 进程 (Daemon) ， 在 
Windows 系统 中 为 服务 (Service) 。 由 于 Apache 服务 器 的 启动 阶段 比较 耗费 时 间 和 资源 ， 
因此 它 一 般 在 操作 系统 局 动 时 被 司 动 并 一 直 运 行 。 

Apache 的 运行 分 为 启动 阶段 和 运行 阶段 。 启 动 阶段 时 ，Apache 以 特权 用 户 root 启动 ， 
进行 解析 配置 文件 、 加 载 模块 和 初始 化 一 些 系统 资源 (例如 日 志文 件 、 共 享 内 存 段 、 数 据 库 
连接 ) 等 操作 。 处 于 运行 阶段 时 ，Apache 放弃 特权 用 户 级 别 ， 使 用 非特 权 用 户 来 接收 和 处 
理 网 络 中 用 户 的 服务 请 求 。 这 种 基本 安全 机 制 可 以 阻止 Apache 中 由 于 一 个 人 简单 软件 错误 
(也 可 能 是 模块 或 脚本 ) 而 导致 的 严重 系统 安全 漏洞 ， 例 如 微软 的 IIS 就 曾 遭 受 “ 红 色 代 人 码 
(Code Red) ”和 “ 尼 姆 达 (Nimda) ”等 恶意 代码 的 游 出 攻击 。 

Apache 的 主 配置 文件 通常 为 httpd.conf。 但 是 由 于 这 种 命名 方式 为 一 般 惯 例 ， 并 非 强 制 
要 求 ， 因 此 对 于 提供 rpm 或 者 deb 包 的 第 三 方 ，Apache 发 行 版 本 可 能 使 用 不 同 的 命名 机 制 。 
另外 ，httpd.conf 文件 可 能 是 单一 文件 ， 也 可 能 是 通过 使 用 Include 指令 包含 不 同 配置 文件 的 
多 个 文件 集合 ， 有 些 发 行 版 本 的 配置 非常 复杂 。httpd.conf 文件 是 一 个 文本 文件 ， 在 系统 局 
动 时 被 未 行 解析 。 访 文件 由 指令 、 容 右 和 注释 组 成 。 配 置 文件 内 允许 有 空 行 和 空格 ， 它 们 在 
解析 时 被 忽略 不 计 。 
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下 载 Apache 软 件 





download.cgi 下 载 Apache 的 最 新版 本 。 


47M Apache 网 页 服务 器 的 首要 工作 便 是 到 Apache 的 官方 网 站 http://httpd.apache.org/ > 


下 载 的 步骤 如 下 。 
(1) 打开 下 浏览 
官方 网 站 ， 如 图 1-3 所 示 。 
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Downloading the Apache HTTP Server 
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(25 在 这 个 页 面 中 有 许多 的 下 载 选 项 ， 


Wb aurt 





1-3 打开 Apache 官方 网 站 


单 击 选择 页 面 上 的 “httpd-2.2.19-win32-x86- 


no_sslmsi” 文 字 ， 下 载 Apache 的 目 动 安装 程序 ， 如 图 1-4 所 示 。 
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The Apache HTTP Server Project is pleased to announce the release of Apache HTTP Server (httpd) 
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attempt to upgrade from these previous verons Modules compded for Apache 2 2 should contas to 
work for all 2 2 x releases 

> Unix Source: btpa-22 19 tar ba? (PGP) M SJ[SHA]] 

e Win32 Source: kzpd-2 2 19-932 PGP][MD5] A 

e. Win32 Binary without crypto (no "d. a) A Inztalder) hiss 19-wn22-z25-ns tilt 

[EGP] [MD5) [SHA!] 
. Was? herida, OptnSSL 0.3. Se (MSI Installer): Hapd-2 wn32-x96-openss- 
b 9 Ar ma [PGP] [MD5] [SHA t] 
. Noire Binary apache 22 19.nemware zip [PGP] [MD5] [SHA 1] 
Coher fioc * 
O iste 


1-4. 选择 相应 的 文件 下 载 
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说 明 : 
本 书 所 下 载 的 是 编写 此 书 时 的 最 新 版 本 ， 由 于 Apache 经 常 更 新 版 本 ， 读 者 可 能 会 下 载 
到 不 同 的 最 新 版 本 ， 这 不 会 影响 后 面 的 操作 与 设置 。 





1.2.3 m Apachelll 55 8& E 


完成 下 载 Apache 的 安装 程序 后 ， 双 击 下 载 的 可 执行 安 闭 文件 〈 在 光盘 中 system. 文件 夹 
下 也 有 下 载 的 安装 文件 )， 如 图 1-5 所 示 。 


TF AmE SEV 收藏 IAM 大助 0 
Q RB - O $ PORR voit pu 
地 址 部 ) £e D: system " 





文件 和 文件 来 任务 


CJ ARAR 
Q 将 这 个 文件 到 发 到 


共享 此 文件 夹 
z Apache-2. 2 19-w ie" MylManagerlite.exe  mysqgl-5.5.13-win3... php-5.2.1T-Win32-... 
x8b5-no ssl.m 


aa 本 地 磁盘 QD 
O 我 的 文档 
p 共享 文档 
3 我 的 电脑 
篇 网 上 邻居 








66.2 MB 时 我 的 电脑 
图 1-5 ”选择 文件 安装 
装 的 步骤 如 下 。 
n JFARZEXB. Apache 安 闭 精 灵 会 提示 将 安装 Apache 服务 右 ， 并 有 警告 信息 ， 如 
图 1-6 所 示 。 











i Apache HITE Server 2.2 — Installation Wizard 


Welcome to the Installation Wizard for 
Apache HTTP Server 2.2.19 


The Installation Wizard will install Apache HTTP Server 2.2.19 
an your computer, To continue, click Next. 


WARMING: This program is protected by copyright law and 
international treaties, 


图 1-6 开始 安装 
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(2) S íi Wet» | 按钮 ， 继 续 安 装 的 程序 。 请 选择 “I accept the terms in the license 
agreement” 同 意 合约 的 授权 ， 进 行 继续 安装 ， 如 图 1-7 所 示 。 





im Ápache HTIE Server 2.2 — Installation Wizard 


License Agreement | © 


Please read the Following license agreement carefully. 


Apache License 
Version 2.0, January 2004 
http://www.apache.org/licenses/ 
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 


1. Definitians. 


"License" shall mean the terms and canditions far use, repraductian, and 
distribution as defined by Sections 1 through 98 ofthis document. 


($5 I accept the terms in Ehe license agreement 


(OI do not accept the terms in the license agreement 





图 1-7 同意 安装 


(3) 单 击 Mets 按钮， 继续 安装 程序 ， 打 开 “Read This First CHAAR)” XNE, 
如 图 1-8 所 示 。 





im Ápache HITP Server 2.4 — Installation Wizard 


Read This First 


Read this Before Running Apache on Windows, 


Apache HTTP Server 


What iz it? 

The Apache HTTP Server is a powerful and flexible HTTPH.1 compliant web server. 
Originally designed as a repnlacementfarthe MCSA HTTP Server, it has grown to be 
the mast popular web server an the Internet. As a project af the Apache Software 
Foundation, the developers aim ta collaboratively develop and maintain a robust, 
commercial-grade, standards-based server with freely available source code. 


The Latest Version 


Details af the latest versian can he found an the Apache HTTP server project page 
under: 


http: httpd.apache.ara 


"t 
DT---.-..---..Ll-4:-.- 一 一 


图 1-8 “Read This First (预览 内 容 )” 对 话 框 


(4) Æ “Read This First (预览 内 容 ，)” 对 话 框 中 主要 是 介绍 Apache HTTP Server 














(Apache 网 页 服务 器 ) 的 一 些 基 础 知识 ， 初 次 使 用 的 读者 可 以 认真 了 解 一 下 ， 以 方便 进一步 
JEH o Hub met Jt. 打开 “Server Information (服务 器 信息 )” 对 话 框 ， 自 行 设 定 服 
务 器 和 域名 名 称 ， 并 要 输入 管理 员 的 联系 邮箱 ， 如 图 1-9 所 示 。 
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im Apache HITP Server 2.2 一 Installation Wizard 


Server Information 


Please enter vour server's information, 


Metwork Domain (e.g. somenet. com} 
Imyserver 


Server Mame (e.g. wiww,somenet,com): 


Imyserver 


&drministratar's Email Address (e.g. webmaskerisomenet.com): 


|designemt? 163.com 


Install Apache HTTP Server 2.2 programs and shortcuts Far: 


($5 For All Users, on Port 8D, as a Service -- Recommended, 
CO only For Ehe Current User, an Pork 8080, when started Manually, 








| 1-9 “Server Information (服务 器 信息 ) ”对 话 框 


(5) 设 定 完成 后 ， 再 单 击 ， Next > | 按钮 ， 继 续 进 行 下 一 步 的 安装 。 打 开 “Setup Type 
(安装 类 型 )” 对 话 杠 ， 这 里 有 Typical (上 典型) 和 Custom (HEX) 安装 两 个 单 选 项 ， 如 
图 1-10 所 示 。 





im Apache HITP Server 2.2 — Installation Wizard 


Setup Type 
Choose the setup type that best suits your needs. 


Please select a setup type. 


C5 Typical 


Typical program Features will be installed. (Headers and Libraries 
For compiling modules will nat be installed.) 


Choose which program Features you want inskalled and where thew 
will be installed. Recommended For advanced users. 





图 1-10 “Setup Type“〈 安 装 类 型 ) ”对 话 框 


(6) 单 击 选择 Custom (HEX) 单 选 按钮 ， 再 单 击 | Next > | 按钮 ， 打 开 “Custom 
Setup (H ENZ NA)” Hite, WK 1-11 所 示 。 这 里 将 选择 所 有 的 内 容 进行 安装 ， 以 
方便 后 面 PHP 程序 的 开发 应 用 需要 。 由 于 Apache 预 设 的 路 径 有 点 长 ， 为 了 方便 起 见 ， 本 
书 将 安装 路 径 改 成 C:\Apache， 单 击 Change (改变 ) 按钮 ， 将 服务 器 的 安装 路 径 设 置 为 
C:\Apache\. 

CI) 单 击 ，Next WH, IFF “Ready to Install the Program (准备 安装 )” 对 话 框 ， 如 
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图 1-12 所 示 。 


im apache HIIP Server 2.2 — Installation Wizard 


Custom Setup 


Select the program Features you want installed. 


Click on an icon in the list below to change how a Feature is installed. 








Feature Description 
| This Feature installs the headers 
and libraries required to compile 
and link additional modules. 


| 日 &9-]Apache HTTP Server 2.2.19 


B-E &-| — Runtime 
Build Headers and Libraries 


Er | APR Icony Code Pages 
& » | Apache Documentation 
& » | Apache Service Taskbar Icon This Feature requires 5340KB on 
vour hard drive. 





Install to: 
CilApachel 


( deme. 





图 1-11 


(8) 接 下 来 开始 进行 安装 ， 
(9) 安装 完成 后 ， 单 击 | Einish 


“Custom Setup〔 目 定义 安装 内 容 ) ”对 话 框 





SER 


u” 


Please wait while the Installation Wizard installs Apache HTTP Server 
2.2.19, This may take several minutes. 


ie apache HITP Server 2.2 — Installation Fizard 


Installing Apache HTTP Server 2.2.19 


The program Features you selected are being installed. 


Status: 
Copying new Files 
BERRRERRRRRRRRRRARWARRARRMAARMRRANRRRAMNARRMAARMEREN 


图 1-13 ”安装 过 程 


装 与 设 定 就 完成 了 。 











Apache Jl: 25-35 Eh] 4. 








Ready to Install the Program 


The wizard is ready to begin installation. 


Click Install to begin the installation. 


If you want to review or change any of your installation settings, click Back. Click Cancel to 
exit the wizard. 


图 1-12 准备 安装 对 话 框 


法 的 过 程 如 图 1-13 所 示 。 
| 按钮 ， 如 图 1-14 Wr. 


13 apache HIIP Server 2.2 —- Installation Fizard 


Installation Wizard Completed 


The Installation Wizard has successfully installed Apache HTTP 
Server 2.2.19, Click Finish to exit the wizard. 


图 1-14 Sim 





Apache 服 务 


JJC Apache 服务 器 后 ， 首 先 要 测试 表面 的 安装 与 设 定 是 耕 成 功 。 由 于 是 在 本 机 
本 Apache 服务 右 ， 因 此 它 的 HTTP HEHEA INIS EKE http://localhost. 
首先 打开 正 浏览 器 ， 在 网 址 列 输入 http://localhost， 如 果 能 顺利 开启 如 图 1-15 所 示 的 网 
页 画面 ， 束 表示 Apache 服务 器 服务 成 功 让 5I. 
Apache 服务 器 的 服务 ， 与 PHP 网 页 的 执行 有 很 重要 的 关联 ， 因 此 接 下 来 要 说 明 Apache 
服务 器 的 设 定 与 操作 。 


器 的 操作 j 


— 
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ictrosoft Internet Explorer 

xc) (Wc EEN FRA IAT) WMH E 
OD- DRAA PRR wea 6 2-5 

IRIE OO AE) http //1ses1hast/ -Arek wv EJA uv Osud: c 


It works! 








1-15 测试 成 功 页 面 


1. Apache 服务 器 的 启动 

"AXE Apache 服务 器 安装 完成 的 页 面 上 上， 已 经 勾 选 “for All User, on Port 80, as a Service- 
Recommended.” 的 选项 ， 那 么 Apache 整 已 经 日 动 局 动 ， 可 以 在 Windows 工作 列 上 的 系统 图 
bi AH Y "EN. 

WMR Apache 服务 器 保 止 服务 后 要 再 局 动 Apache 服务 器 ， 在 Windows 系统 图 标 中 的 总 
图 标 上 ， 单 击 弹 出 快捷 菜单 ， 再 单 击 选 择 Start (开始 ) 就 可 以 重新 启动 Apache 服务 器 的 
服务 。 

2. Apache 服 务 器 的 停止 

如 果 要 停止 Apache 服务 器 ， 在 Windows 系统 图 标 中 的 : 咏 图 标 上 ， 单 击 弹出 快捷 末 持 ， 
Hifi Stop (停止 ) 束 可 以 停止 Apache 服务 占 的 服务 ， 这 时 
Apache 的 系统 图 标 变 成 咏 ， 如 图 1-16 所 示 。 

3. Apache 服 务 器 的 主 目 录 

正常 情况 下 ，Apache 服务 器 主 目 杂 的 预 设 位 置 在 C:\Program 
Files\Apache Software Foundation\Apache 路 径 下 。 由 于 本 书 将 
Apache 服务 器 安装 在 CNApache 文件 夹 中 ， 因 此 主 目录 也 在 C:\Apache 路 径 下 ， 打 开 的 一 级 
目录 如 图 1-17 所 示 。 











Festart 


1-16 窗口 页 面 










| Xi) mm mao umo IrN-) Won 
GAE- Oo d$ ^x ox D 


xtd HESS 
c3 bikk-- CHE 
g ucxMEWME | 
Has | ary ar | hide: — — MON ici: 
ee 


d pum 











图 1-17 打开 的 文件 夹 目 录 
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Apache 服务 器 各 主 目 录 的 意义 与 用 途 说 明 如 表 1-1 所 示 。 


表 1-1 Apache 文件 说 明 


目录 名称 意义 与 用 途 e 
bin 存放 编译 程序 及 指令 文件 LI 
"s 存放 用 于 设置 支持 egi 的 文件 h 
conf 存放 服务 器 结构 档案 ，httpd.conf 文件 是 设置 服务 器 的 主要 文件 
error 存放 运行 出 错时 提示 用 的 文件 
htdocs 存放 运行 成 功 时 显示 的 文件 ， 该 版 本 只 有 简单 的 一 行 字 
icons 存放 服务 器 显示 相应 网 页 的 所 有 图 片 文 件 
include 存放 文 持 服务 器 的 一 些 主要 包含 文件 
lib 存放 Apache 所 需 的 lib 文件 
logs 存放 日 志 档 案 
manual 存放 服务 器 的 模块 功能 文件 
modules 存放 网 页 应 用 程序 的 目录 


4. Apache 服 务 器 的 网 站 目录 

在 Apache 服务 右 中 ， 所 有 PHP 网 页 的 网 站 目录 都 必须 放 到 CApache/htdocs 文件 夹 内 。 例 如 
号 了 一 个 名 为 website 的 PHP 网 站 目录 ， 则 这 个 website 的 网 站 目录 位 置 应 该 放 到 
C:\Apache\htdocs\ 的 文件 夹 中 。 当 然 也 可 以 直接 打开 httpd.conf 文件 ， 找 到 如 图 1-18 所 示 的 位 置 ， 
将 DocumentRoot “C:/Apache/htdocs” 这 一 行 代 码 进行 相应 的 设置 即 可 更 改 为 新 的 网 站 目录 。 











P httpd. conf 一 记事 本 
WED RED BRO SEV 才 助 00 


# DocumentRoot: The directory out of which you will serve your] 
# documents. By default, all requests are taken from this directory, but 
# symbolic links and aliases may be used to point to other locations. 





DocumentRoot "C:/Rpache/htdocs" 


# Each directory to which Apache has access can be configured with respect 
# to which services and features are allowed and/or disabled in that 

it directory (and its subdirectories). 

Hu 


# First, ve configure the "default" to be a very restrictive set of 
# features. 
H 


<Directory /> 
Options FollowSymLinks 





图 1-18 设置 网 站 文件 位 置 





进行 到 此 ， 已 经 完成 了 PHP 网 页 开发 环境 Apache IKI ari 


PHP 的 安装 与 配置 


接 下 来 的 工作 就 是 设 定 PHP 的 执行 环境 。PHP 的 安装 与 配置 有 多 种 方法 ， 这 里 介绍 使 
用 PHP 官方 提供 的 安装 包 来 进行 安装 的 方法 。 
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下 载 PHP 


安装 好 Apache 服务 器 以 后 ， 下 面 开始 安装 PHP. PH 开发 软件 包 是 开发 PHP 程序 的 核 
心 ， 该 软件 包 需 要 从 PHP 官方 网 站 下 载 ， 地 址 为 http:Wwww.php.net。 上 有 目 前 PHP 最 新 的 版 本 
是 2011 Æ 3 H 22 日 发 布 的 PHP5.2.17， 这 里 以 该 版 本 为 例 ， 下 载 的 页 面 如 图 1-19 所 示 。 


E: PHP For Windows: Binaries and sources Releases — Nicrosoft Internet Explorer 


SEO) 编辑 FF) 查看 WW) 收藏 和 IAM $8500 
Q mB - [) |j (9 JO Sek wx 6 e SBL 


ui 





输入 关键 词 搜索 M Eea dE Qs E 








C++ Runtime (x64) installed = Zip [9.97MB] 





Do NOT use YC9 version with shal: 30e2e65e80cec780a42d0b7eb5fedSd42bf20eb4a 
apache.org binaries 

m Installer [20.24MB] 
wC9 versions of Apache can be 
fetched at &pache Lounge. We 
use their binaries to build the 
Apache SAPIs. 


shal: 2145f6adf72ab5faaD67c52163c6b1cil8c47eedd 


a Debug Pack [4.94MB] 
shal: 77lb2587ea0087aa01fcc47d438597elee46e5e4 


Archives VC6 x86 Thread Safe (2011-Mar-22 13:29:30) 


Past releases are available — 
= Zip [10.06MB] 


versions not found there can be shal: 23eicf2f6elbf64585ae92146234085748fcc939 
found at the Museum, 
a Installer [20.41MB] 


shal: p A N MEER 15796f0a390 
a Debug Pack [4.99MB] 
shal: 027c38420ee21c049345b3baea149d083e558a4c 





uj http: //windows. php. net/downloads/releases/php-5.2.1T-Win32-VCB5-x8Bb. msi 


图 1-19 FÆ PHP 的 最 新 安装 版 本 
从 PHP 5.2.10 版 本 开始 (现在 有 PHP 5.2.10 和 PHP5.3 两 个 版 本 )， 有 Non-Thread Safe 

















与 Thread Safe 两 种 版 本 的 可 供 选 择 。 这 两 种 版 本 有 何不 同 ， 作 为 使 用 者 来 说 又 应 该 如 何 选 
择 呢 ? 先 从 字面 意思 上 理解 ，Non-Thread Safe 束 是 非 线 程 安 全 ， 在 执行 时 不 进行 线程 
(Thread) 安全 检查 ，Thread Safe 束 是 线程 安全 ， 执 行 时 会 进行 线程 (Thread) 安全 检查 ， 以 
防止 有 新 要 求 束 局 动 狐 线程 的 CGI 执行 方式 耗 尽 系统 资源 。 再 来 看 PHP 的 两 种 执行 方式 : 

ISAPI 和 FastCGI。FastCGI 执行 方式 是 以 单一 线程 来 执行 操作 ， 所 以 不 需要 进行 线程 的 安全 
检查 ， 除 去 线程 安全 检查 的 防护 反而 可 以 提 蜗 执行 效 紊 ， 所 以 ， 如 果 是 以 FastCGI (无 论 拱 
配 IIS6 或 IS7) 执行 PHP ， 部 建议 下 载 、 执 行 Non-Thread Safe 的 PHP (PHP. 的 二 进位 
文档 有 两 种 包装 方式 : msi zip ， 请 下 载 zip 套件 )。 而 线程 安全 检查 正 是 为 ISAPI 方式 的 
PHP 准备 的 ， 因 为 有 许多 PHP 模块 都 不 是 线程 安全 的 ， 所 以 需要 使 用 Thread Safe 的 PHP. 

本 书 是 使 用 Apache 服务 器 ， 所 以 要 选择 VC6 版 本 的 Thread Safe 这 个 PHP 来 安装 。 


























安装 PHP 


下 载 后 即 可 以 开始 PHP 的 安 逆 ， 有 具体 的 安 儿 步骤 如 下 。 
CD 双击 下 载 的 文件 php-5.2.17-win32-installermsi〈 在 光盘 中 system. 文件 夹 下 也 有 下 载 
的 安 冯 文 件 )， 弹 出 “Welcome to the PHP 5.2.17 Setup Wizard 〈 欢 迎 安 装 PHP 安装 程序 )” 对 








第 1 章 EEEE TA 





iE, Un] 1-20 所 示 。 

(2) 单 击 [_nex | 按钮 ， 打 开 “End-User License Agreement (终端 用 户 许可 )” 对 话 框 。 
请 单 击 选择 “Iaccept the terms in the license Agreement” 复 选 按 钮 ， 同 意 合约 的 授权 ， 继 续 进 
41229, WK 1-21 所 示 。 


13 PHP 5.2.17 Setup T PHP 5.2.17 Setup 


End-User License Agreement ue. E 


Welcome to the PHP 5.2.17 Setup Wizard 


Please read the Following license agreement carefully 


The Setup Wizard will install PHP 5.2.17 on your computer. 
Click Next to continue or Cancel to exit the Setup Wizard. 
Please disable any virus detection software you may have 
running during this installation. 


The PHP License, version 3.01 
Copyright (c) 1999 - 2010 The PHP Group. àÀll rights 


Redistribution and use in source and binary forms, 
with or without 
modification, is permitted provided that the 


[7]I accept the terms in the License Agreement 





图 1-20 ”欢迎 安装 界面 图 1-21 同意 安装 
(3) 单 击 [_ wee _ | 按钮 ， 打 开 “Destination Folder (安装 路 径 文 件 )” 对 话 框 时 ， 单 击 
Browse (JV) 按钮 来 更 改 PHP 的 安 北 路 人 笃 ， 这 里 为 “C:\PHP\W 目录 ， 如 图 1-22 所 示 。 
(4) 设置 PHP 安装 路 径 之 后 ， 单 击 [Next ”| 按钮 ， 选 择 安装 Apache 版 本 号 ， 这 里 为 
Apache 2.2x Module， 如 图 1-23 所 示 。 





iŞ PHP 5.2.17 Setup iŞ PHP 5.2.17 Setup 


Destination Folder Web Server Setup 


Click Next to install to the default Folder or click Browse to choose another. Select the Web Server you wish to setup. 


O Apache 1.3.x Module 
O Apache 2.0.x Module 
© Apache 2.2.x Module 
O Apache CGI 

CO IIS ISAPI module 

QO IIS FastCGI 

(II5 CGI 

CONSAPI 

CO Xitami 

CO Sambar Server 

CO NetServe Web Server 
CO Other CGI 

CO Do not setup a web server 


Install PHP 5.2.17 to: 


cnPHPI 





图 1-22 设置 安装 路 任 图 1-23 ”选择 Apache 版 本 号 


(5) 再 单 击 [_ Nex _ | 按钮 ， 选 择 Apache 服务 器 的 安装 路 径 ， 如 图 1-24 所 示 。 

(6) 然后 单 击 [_ Nex | 按钮 ， 打 开 “Choose Items to Install (选择 安装 项 目 )” 对 话 框 ， 
选择 要 安装 的 PHP 组 件 ， 建 议 全 部 选择 安装 ， 设 置 如 图 1-25 Br. 

特别 说 明 : 

在 安装 的 时 候 一 定 要 展开 PHP 的 列 选项 ， 勾 选 MySQL 的 组 件 ， 这 样 才 能 把 PHP 和 
MySQL 数据 库 关联 起 来 ， 以 方便 进一步 的 数据 库 连 接 使 用 . 

CI) 设置 完成 后 单 击 [_Next — | 按钮 ， 打 开 “Ready to install PHP. (准备 安装 )” 对 话 框 ， 
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如 图 1-26 所 示 。 
(8) HAt nta 按钮 开始 安装 PHP， 安 装 的 过 程 会 有 安装 进度 提示 ， 如 图 1-27 
所 示 。 


1282: 5.2.17 Setup 1282: 2 5.2.17 Setup 


Apache Configuration Directory Choose Items to Install 


Browse to select the directory containing the Apache Configuration Files (c... Select the way you want features to be installed. 


人 Click the icons in the tree below to change the way features will be installed. 





z Eds" PHP ^ Optional Extras For the PHP Install 


=M Script Executable 


Sr v | Register * ,ph 


|c:\apache' 


Browse... TE — SM Extensions 


Ez | bzip2 This Feature requires OKB on your 
& » | Curl hard drive. It has 2 of 2 

& ~| DBA subfeatures selected. The 

E ~ | dBase z subfeatures require 13MB on your 
hard drive. 








> 





图 1-24 选择 Apache 服务 器 安装 路 径 图 1-25 ”选择 安装 项 目 


ig PHP 5.2.17 Setup 1282: 2 5.2.17 Setup 


Ready to install PHP 5.2.17 Installing PHP 5.2.17 


Click Install to begin the installation. Click Back to review or change any of your Please wak while the Setup Wizard installs PHP 5.2.17. 
installation settings. Click Cancel to exit the wizard. 


Status: 


aono 


Cancel 





图 1-26 准备 安装 对 话 框 图 1-27 安装 过 程 


(9) 安 状 完 成 后 会 显示 完成 对 话 框 ， 提 示 成 功 安 灾 了 PHP 软件 包 ， 单 击 Finish 按钮 完 
成 安装 ， 如 图 1-28 所 示 。 

C100 这 是 最 关键 的 一 步 ， 需 要 将 安装 后 的 CAPHPVxt 文件 夹 下 的 驱动 文件 都 复制 到 
CANWINDOWSNsystem32 Fh. 

如 果 读 者 在 PHP 官方 网 站 下 载 的 PHP PFE SKRIET E, JA TEBCBLN 
需要 设置 环境 变量 。 具 体 设置 环境 变量 的 方法 如 下 : 首先 将 PHP 包 解 压 到 指定 文件 夹 中 作 
为 PHP 的 根 目 录 ， 例 如 “CNPHP” 目 录 中 ， 然 后 再 配置 Apache 运行 时 需要 加 载 的 
php5apache2 2.dll 文件 。 方 法 是 将 PHP 的 安装 路 径 退 加 到 Windows 系统 中 Path 路 径 的 下 
面 ， 右 击 “ 我 的 电脑 >， 选择 “属性 ”命令 ， 在 弹出 的 “系统 属性 ”对 话 框 中 切换 到 “ 高 
级 ”选项 卡 ， 青 蛙 击 “环境 变量 ”按钮 ， 打 开 “ 环 境 变 量 ” 对 话 框 ， 从 “系统 变量 ”列表 中 
找到 Path 路 径 ， 单 击 “ 编 辑 ” 按 钮 后 ， 在 弹出 对 话 框 的 “变量 值 ” 文 本 框 中 将 C: PHP 追加 
到 路 径 中 ， 如 图 1-29 所 示 。 
























































编辑 系统 变星 





Click the Finish button to exit the Setup Wizard. 














SI NSystemRootWAsystem32; Syst 





AERE (S) 


变量 

ComSpec C: WINDOWS*system32^emd. exe 
FP NO HOST C... T 
NUMBER OF PR... 

üs T" 

Path Es Wei c: : \HINDOWS Vsysten32; E: m * 
DATuUTVT 


Back. Cancel 

















图 1-28 ”完成 安装 图 1-29 “编辑 系统 变量 ”对 话 框 设置 


eI 配置 Apache 支 持 PHP 


安装 完成 PHP 后 ， 并 不 能 直接 在 Apache 里 运行 PHP 文件 ， 还 要 进一步 配置 Apache 才 
可 以 支持 PHP 的 运行 ， 配 置 的 方法 很 简单 ， 方 法 如 下 。 
(1) 进入 Apache 服务 器 的 安 北 文 件 夹 ， 如 图 1-30 所 示 。 
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图 1-30 进入 Apache 服务 器 的 安装 过 文件 夹 


(2) 双击 进入 conf 目录 ， 打 开 httpd.conf 文件 ， 在 文件 的 最 下 方 增加 下 列 3 行内 容 ， 如 
图 1-31 所 示 : 
LoadModule php5 module "CAPHPWphp5apache2 2.dll" 
AddType application/x-httpd-php .php 
PHPIniDir "C:\php" 
该 段 代 码 中 ， 第 1 行 表示 要 加 载 的 模块 在 哪个 位 置 存 储 ; 
第 2 行 表 示 将 一 个 MIME 类 型 绑 定 到 菏 个 或 条 坚 扩展 名 。.php 只 是 一 种 扩展 名 ， 这 里 









7PHP-^ 





可 以 设 定 为 .html、.php2 45; 


Tr S48) Ato) 查看 [9) WR500 


u E SSL/TLS) connections 
"Include conf/extra/httpd-ssl.conf 


# Note: The Following must must 
# starting without SSL on e hieten ith - Fem equivalent 
q" but a statically conpiled-in mod ssl 


*ItModule ssl module» 

SSL RandonSeed startup builtin 
SSLRandonSeed connect builtin 
C/VrHnodule» 


0adiModule phps module “C:\PHP\phpSapache2_ 2.d11” 
ddType application/x-httpd-php -php 
HPIniDir "C:Xphp" 





1-31 加 入 支持 PHP 的 代码 
第 3 行 表 示 PHP 押 在 的 初始 化 路 径 。 
此 时 PHP 环境 就 配置 完成 了 。 
(3) 同样 查找 DirectoryIndex 这 个 代码 ， 将 其 后 面 的 代码 改 为 


DirectoryIndex index.php default.php index.html 


表示 默认 访问 站 点 时 打开 的 首页 顺序 是 index.php default.php index.html. 


(SOUL 测试 PHP 环 境 


PHP 软件 包 和 安装 完成 后 ， 束 可 以 在 Apache 中 测试 PHP 环境 是 否 正 确 了 。 下 面 创建 一 个 
PHP 示例 来 测试 ， 该 示例 是 执行 一 个 带 有 PHP 脚本 的 程序 ， 如 果 执 行 成 功 ， 则 证 明 PHP 安 
装 成 功 。 打 开 Apache 下 的 htdocs 目录 〈 这 里 为 C:\Apache\htdocs)， 然 后 使 用 记事 本 创建 一 
个 名 为 test.php 的 文件 ， 再 添加 如 下 代码 到 文件 中 。 


<?php 
phpinfo(); /输出 PHP 环境 信息 





?> 


保存 test.php 文件 ， 然 后 在 IE 浏览 器 的 地 址 栏 中 输入 “http:/localhost/test.php”， WR E 
zs PHP 的 相关 信息 ， 则 证 明 PHP ee 如 图 1-32 SS 否则 安装 失败 。 





System [Wines NT 6647514373C0420 5.1 baid 2600 
EET 


= 








1-32 test.php 页 面 效果 
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PHP 配置 文件 


安装 PHP 后 还 可 以 根据 需要 编辑 php.in; 文件 对 PHP 的 配置 进行 设置 。 下 而 就 对 PHP 
配置 文件 phpini 的 组 织 方式 进行 简要 的 说 明 。 文 件 命 名 为 phpini 的 原因 之 一 是 它 遵 循 许多 
Windows 应 用 程序 中 INI 文件 的 常见 结构 。php.ini 是 一 个 ASCII 文本 文件 ， 并 且 被 分 成 几 个 
不 同名 称 的 部 分 ， 每 一 部 分 包括 与 之 相关 的 各 种 变量 。 

每 一 部 分 类 似 于 如 下 结构 : 





[MySection] 
variablez" value" 


anothervariable-"anothervalue" 


各 部 分 的 名 称 通过 方 括号 “[ ]” 括 起 来 放 在 顶部 ， 然 后 是 任意 数量 的 变量 名 =“ 值 ” 
对 ， 每 一 对 占 单 独 一 行 。 如 来 行 以 分 扎 “;” 开 头 ， 则 表明 该 行 是 注释 语句 。 

在 php.ini 中 允许 或 茶 止 PHP 蕊 能 变 得 非常 简单 ， 上 只 需要 将 相关 语句 注释 而 无 需 删除 ， 
该 语句 就 不 会 家 系统 解析 。 特 别 是 ， 当 而 望 在 一 段 时 间 以 后 重新 打开 东 种 功能 的 时 候 特 别 方 
便 ， 因 为 不 需要 在 配置 文件 中 将 此 行 删除 。 

如 下 面 php.ini 文件 中 的 一 个 片段 : 


























$555555555255555555595? 
; Language Options ; 


; Enable the PHP scripting language engine under Apache. 

engine = On 

; Enable compatibility mode with zend engine 1 (PHP 4.x) 

zend.zel compatibility mode = Off 

; Allow the <? tag. | Otherwise, only <?php and <script> tags are recognized. 
; NOTE: Using short tags should be avoided when developing applications or 
; libraries that are meant for redistribution, or deployment on PHP 

; servers which are not under your control, because short tags may not 

; be supported on the target server. For portable, redistributable code, 

; be sure not to use short tags. 

short open tag = Off 

; Allow ASP-style <% 965 tags. 

asp. tags = Off 

; Ihe number of significant digits displayed in floating point numbers. 
precision = 14 


在 这 个 文件 中 可 对 PHP 的 12 个 方面 进行 设置 ， 包 括 : 语言 选项 、 安 全 模式 、 语 法 突出 
显示 、 某 项、 资源 限制 、 错 误 处 理 和 日 志 、 数 据 处 理 、 路 人 径 和 目录 、 文 件 上 传 、Fopen A% 
髓 、 动 态 扩展 和 模块 设置 。php.ini 文件 存放 在 PHP 的 安装 路 径 ， 在 每 次 局 动 PHP 时 都 会 读 
取 。 因 此 ， 在 通过 修改 php.ini 文件 改变 PHP 配置 之 后 ， 需 要 重启 Web 服务 器 以 使 配置 改变 
生效 。 本 书 的 实例 需要 配置 的 对 象 为 














magic quotes gpc = On 








PHP+ 


magic quotes gpc 功能 为 : 是 否 目 动 为 GPC(egebpostcookie) 传 来 的 数据 中 的 \”\”N 加 上 
bz o 

如 果 magic quotes gpc-On. 3xk|lH| 1, PHP ITAMA HJ post. get. cookie 过 来 的 
数据 增加 转 义 字符 “”， 以 确保 这 些 数 据 不 会 引起 程序 ， 特 别 是 数据 库 语 句 因为 特殊 字符 引 
起 的 污染 而 出 现 致命 的 错误 。 

在 magic_quotes_gpc=On WEW F, WRA WAA E Ch MAI C RA 
线 CO 与 NUL (NULL 字符 ) SE AU Eb. KEFEN EMA. MRAN 
项 为 Off， 返 回 0 ,. MARIAH addslashes 这 个 函数 来 为 字符 串 增 加 转 义 。 


和 
m Ix BLA 
T RC. PCIE 
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安装 与 应 用 MySQL 数 据 库 


网 站 数据 库 束 是 用 来 储存 大 量 的 网 站 数据 以 及 更 狐 任 何 数 据 信 息 变 动 的 ， 也 就 是 说 通过 
数据 库 的 查询、 新 增 、 修 改 与 删除 ， 网 站 信息 也 随即 跟着 变动 。 本 书 末 用 MySQL 作为 网 站 
的 数据 库 ， 可 以 到 MySQL 的 官方 网 站 http:/www.mysql.com 下 载 MySQL 版 本 。 


| MySQL(ÍS ST 


MySQL 是 一 个 真正 的 多 用 户 、 多 线程 SQL 数据 库 服务 器 。SQL “〈 结 构 化 查询 语言 ) 是 
世界 上 最 流行 的 、 标 准 化 的 数据 库 语 言 。MySQL 是 以 一 个 客户 机 /服务 器 结构 实现 ， 由 一 个 
服务 器 守护 程序 mysqld 和 很 多 不 同 的 客户 程序 和 库 组 成 。 

SQL 是 一 种 标准 化 的 语言 ， 它 使 得 存储 、 更 新 和 存 取 信息 更 容易 。 例 如 ， 能 用 SQL 语 
言 为 一 个 网 站 检索 产品 信息 及 存储 顾客 信息 ， 同 时 MySQL 也 允许 用 户 足 够 快 和 灵活 地 存储 
记录 文件 和 网 像 。 

MySQL 的 主要 目标 是 快速 、 健 壮 和 易 用 。MySQL 最 初 被 开发 的 原因 是 因为 需要 一 个 
SQL 服务 器 一 一 它 能 处 理 与 任何 可 不 昂 贯 便 件 平台 上 的 数据 库 在 一 个 数量 级 上 的 大 型 数据 
库 ， 而 且 它 的 速度 更 快 。 自 1996 年 以 来 ， 我 们 一 直 在 使 用 MySQL， 其 环境 有 超过 40 
个 数据 库 ， 包 含 10000 个 表 ， 其 中 500 多 个 表 超 过 700 万 行 ， 这 大 约 有 100GB 的 关键 应 
用 数据 。 

MySQL 建立 的 基础 是 已 用 于 高 要 求 的 生产 环境 多 年 的 一 套 实用 例 程 。 尽 管 MySQL 4j 
在 开发 中 ， 但 它 已 经 提供 了 一 个 丰富 和 极其 有 用 的 功能 集 。 

在 这 里 推荐 使 用 MySQL 的 主要 原因 有 以 下 几 点 。 

D 便宜 (通常 是 免费 )。 

2) 网 络 承载 比较 少 。 

3) 经 过 高 度 最 佳 化 〈HighlyOptimized )。 

4) 应 用 程序 通过 它 做 起 备份 来 比较 简单 。 

5) 为 各 种 不 同 的 数据 格式 提供 弹性 的 接口 。 

6) 较 好 学 且 操 作 人 简单 。 

MySQL 的 优点 有 以 下 几 点 。 
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1. Efe 9 2E DH 3E 

针对 多 个 使 用 者 共同 存 取 的 文 持 ，MySQL 内 定 最 大 连接 数 为 100 个 使 用 者。 但 是 ， 即 
使 网 络 上 有 大 量 数 据 往 来 ， 并 不 会 对 查询 最 佳 化 (Query Optimization A £ KEI. 

2. 最 佳 化 

数据 库 结 构 设 计 也 会 影响 到 MySQL 的 执行 效率 ， 例 如 MySQL 并 不 文 持 外 来 键 (Foreign 
Key)， 这 个 缺点 会 影响 到 数据 库 设 计 以 及 网 站 的 效率 。 

对 于 使 用 MySQL 做 数据 库 文 持 的 网 站 ， 应 该 将 重点 放 在 如 何 让 硬盘 存 取 减 少 到 最 低 、 
如 何 让 一 个 或 多 个 CPU 随时 保持 在 高 速 作业 的 状态 ， 以 及 文 持 适当 的 网 络 频 宽 ， 而 非 实际 
上 的 数据 库 设 计 以 及 数据 得 询 状况 。 

3. 多 线程 

MySQL 是 一 个 快速 、 多 线程 (Multithread)、 多 使 用 者 日 功能 强大 的 关系 型 数据 库 官 理 
RA (Relational Database Management System, RDBMS). tiit vi tm- MySQL Žr 
据 库 连接 时 ， 服 务 器 会 产生 一 个 线程 (Thread) 或 一 个 行程 (Process) 来 处 理 这 个 数据 库 连 
接 的 请 求 (Request). 

4. 可 延伸 性 以 及 数据 处 理 能 

MySQL 同时 上 共有 局 度 多 样 性 ， 能 够 提供 给 很 多 不 同 的 使 用 者 接口 ， 包 括 命令 列 、 客 户 剖 操 
作 、 网 页 浏览 器 、 以 及 各 式 各 样 的 程序 语言 接口 ， 例 如 Cer. Perl. Java. PHP 以 及 Python. 

MySQL 可 用 于 UNIX. Windows. OS/2 等 平台 ， 也 束 是 说 它 可 以 用 在 个 人 计算 机 或 者 
是 服务 器 上 。 

5. 便于 学 习 

MySQL 文 持 结 构 化 查询 语言 (Structured Query Laneuage，SQL)， 那 么 精通 数据 库 的 人 
在 一 天 之 内 ， 就 可 以 学 会 MySQL， 对 于 初学 者 来 说 也 非常 容易 上 手 。 


安装 MySQL 数 据 库 


下 载 MySQL 数据 库 的 步骤 如 下 。 
(1) 打开 IE XAS HICE] MySQL 的 官方 网 站 http:/www.mysqlcom， 下 载 MySQL 
数据 库 ， 如 图 1-33 Bron. 
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图 1-33 打开 MySQL 主页 
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(2) 打开 主页 之 后 找到 相关 下 载 文 件 ， 本 书 下 载 的 是 MySQL 的 最 新 版 本 《在 光盘 中 
system. 文件 夹 下 也 有 下 载 的 安 关 文 件 )。 下 载 后 双击 安装 程序 mysg1-5.5.13-win32.msi， 打 开 
“Welcome to the MySQL Server 5.5 Setup Wizard”( 欢 迎 开 始 安装) peru, Ak 1-34 所 示 。 

(3) MySQL 安装 精灵 会 显示 欢迎 界面 ， 并 提示 安装 的 版 本 ， 单 击 L_next_ | 按钮 继续 
安装 程序 ， 打 开 “End-User License Agreement 〈 终 端 用 户 许可 )” 对 话 框 。 请 单 击 选择 “I 
accept the terms in the license Agreement” 复 选 按钮 ， 同 意 合约 的 授权 ， 进 行 继续 安 朔 ， 如 
图 1-35 所 示 。 


B EySQL Server 5.5 Setup 














六 SQL Server 5.5 Setup 


End-User License Agreement 


Welcome to the MySQL Server 5.5 Setup 
Wizard 


Please read the following license agreement carefully 


GNU GENERAL PUBLIC LICENSE 

Ve ion 2, June 1991 
The Setup Wizard will install MySQL Server 5.5 on your 
computer. Click Next to continue or Cancel to exit the Setup 
Wizard. 


Copyright (C) 1989, 1991 Free Software Foundation, Inc., 

51 Franklin Street, Fifth Floor, Boston, Mà 02110-1201 VSA 
Everyone is permitted to copy and distribute verbatim copies 
of this license document, but changing it is not allowed. 


Preamble 


The licenses for most software are designed to take away your 
freedom to share and change it. By contrast, the GNU General Public 
License is intended to guarantee your freedom to share and change 
free 


software--to make sure the software is free for all its users. This 
Copyright (c) 2000, 2011, Oracle and/or its affiliates. All 


rights reserved, [v]I accept the terms in the License Agreement 





图 1-34 开始 安装 图 1-35 同意 许可 安装 


(4) 单 击 [_Nex_ HH, FIIF “Choose Setup Type( 选 择 安装 类 型 )” 对 话 框 ， 要 选择 
MySQL HZR, Mihi Custom (HEX) 单 选 按钮 ， 继 续 进 行 下 一 步 的 安 厂 ， 如 
图 1-36 所 示 。 

(5) 打开 “Custom Setup《〈 目 定义 安装 )” 对 话 框 ， 在 这 个 对 话 框 页面 中 ，MySQL 提醒 
使 用 者 将 MySQL 安装 至 预 设 的 路 径 ， 这 里 将 路 径 改 为 CAMySQL, An 1-37 所 示 。 





iS EySQL Server 5.5 Setup 1 名 NySQL Server 5.5 Setup 


Choose Setup Type Custom Setup 


Choose the setup type that best suits your needs Select the way you want Features to be installed. 


Click the icons in the tree below to change the way Features will be installed. 


Typical 


Installs the most common program Features. Recommended For most users. = 3 ~ | ESTIS Install MySQL Server 





Client Programs 
Debug binaries 


E » | Development Components 


Allows users to choose which program features will be installed and where & z| Debug Symbols This feature requires 22MB on your 
they will be installed. Recommended for advanced users. &9 » | Server data files hard drive. It has 2 of 2 
subfeatures selected. The 


subfeatures require 62MB on your 
M ta hard drive. 
All program Features will be installed. Requires the most disk space. 
Location: CiMysgll 























图 1-36 ”选择 文件 安装 类 型 图 1-37” 设 定 目 定 义 安装 路 径 


(6) 确认 后 ， 单 击 L_Next__ HET. 47 "Ready to install MySQL Server 5.5 (准备 开始 安 
d)" oie, WE 1-38 所 示 。 
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(7) 单 击 __mstal 按钮 打开 “Installing MySQL Server 5.5 (安装 MySQL )” 对 话 
框 ， 提 示 安 装 的 进度 ， 如 图 1-39 Wr. 


s MySQL Server 5.5 Setup | ' im MySQL Server 5.5 Setup 





Ready to install MySQL Server 5.5 Installing MySQL Server 5.5 


Click Install to begin the installation. Click Back to review or change any of your Please wait while the Setup Wizard installs MySQL Server 5.5. 


installation settings. Click Cancel to exit the wizard. 


Status: Copying new files 








图 1-38 ”准备 开始 安装 对 话 框 图 1-39 ”提示 安装 进度 
(8) 由 于 下 载 安 闫 的 是 企业 版 的 MySQL， 安 装 到 最 后 会 打开 “MySQL Enterprise 


(MySQL 企业 版 )” 对 话 框 ， 显 示 该 版 本 的 一 些 信 息 ， 如 图 1-40 所 示 。 
(9) ÁL nts 上 按钮 ， 提 示 进 一 步 的 信息 ， 如 图 1-41 所 示 。 


MySQL Enterprise | NySQL Enterprise 





` A MySQL Enterprise subscription is the most MySQL 
hensive offering of MySQL database " 。 。 
ofl do Muir The MySQL Enterprise Monitor Service 
M Lj S QL. ë business achieves the highest levels of reliability, —-— : 
security, and uptime. | * Quickly identifies your 
Enterprise An Enterprise Subscription includes: most expensive SQL code 
across all your servers. 


1. The MySQL Enterprise Server - The most reliable, secure, and up-to-date * MySQL Advisors and 125+ 
version of the world's most popular open source database. Best Practice Rules ensure 
security and performance. 





2. MySQL Enterprise Monitor Service - An automated virtual datab 


assistant. . 
* Alerts and Expert Advice 


on howto fix problems and 
tune for peak performance. 


-onmoralinio attona 








图 1-40 MySQL 企业 版 信息 图 1-41 进一步 提示 信息 


(10) HAL nets 按钮， 打开 完成 安装 对 话 框 ， 单 击 选 择 “Launch the MySQL 
Instance Configuration Wizard (装载 运行 MySQL 确认 问 导 )” 复 选 按 钮 ， 如 图 1-42 所 示 。 

(11) 单 击 [_Fnish_j 按 钮 ， 打 开 装 载运 行 MySQL 确认 向 导 对 话 框 ， 如 图 1-43 所 示 。 
Hz, FIIF “MySQL Server Instance Configuration Wizard CZ 
模式 确认 )” 对 话 框 ， 这 里 单 击 选择 “Standard Configuration. 〈 标 准确 认 模 式 )” 单 选 按 
钮 ， 如 图 1-44 所 示 。 

(13) 选择 确认 模式 后 再 单 击 |! 让 按钮 ， 打开“ 了 Please set the Windows OPtions 
(设置 Windows 的 选项 )” 对 话 框 ， 单 击 选择 所 有 的 复 选 按钮 ， 其 中 Install As Windows 
Service 表示 将 MySQL 数据 库 服务 器 注册 为 Windows 的 服务 ， 以 方便 管理 ，Launch the 
MySQL Server automatically 表示 目 动 运行 MySQL 数据 库 ; Include Bin Directory in Windows 
PATH 是 把 MySQL 相关 的 命令 行 工具 加 入 命令 行 目 动 人 租 找 的 路 径 中 ， 以 方便 调用 MySQL 命 
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令 。 设 置 后 的 对 话 框 如 图 1-45 所 示 。 


ig EySQL Server 5.5 Setup 





NySQL Server Instance Configuration Wizard 


Welcome to the MySQL Server Instance 
Completed the MySQL Server 5.5 Setup Configuration Wizard 1.0.17.0 


Wizard 
The Configuration Wizard will allow you to configure the 


MySQL Server 5,5 server instance. To Continue, click 


Click the Finish button to exit the Setup Wizard. Next. 


Launch the MySQL Instance Configuration Wizard 











图 1-42 “完成 安装 ”对 话 框 


NySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration MySQL Server Instance Configuration 


Configure the MySQL Server 5,5 server instance. Configure the MySQL Server 5,5 server instance. 


Please select a configuration type. Please set the Windows options. 


[v Install As Windows Service 


"n This is the recommended way to run the MySQL server 
O on Windows, 


Service Name: [MySQL v | 


[V Launch the MySQL Server automatically 


C Detailed Configuration 


"M Choose this configuration type to create the optimal server setup for 
this machine. 


Use Es on machines that do not already have a MySQL server 
installation. This will use a general purpose configuration For the a: 
server that can be tuned manually. Check this option to include the deum containing the 

server | client executables in the Windows PATH variable 


so they can be called from the command line. 





x Back | Cancel | 


<Back | Cancel | 
图 1-44 ”选择 确认 安装 模式 图 1-45 设置 Windows 选项 








| 按钮， 打开 “Please set the security options Ciz E zz ew" op 
i 单 击 选 择 “Modify Security Settings CMA ZR Y EO" RFA, JEU UC AN BU TET 2z 

装 时 设置 的 root 的 密码 ， 本 书 设 置 的 密码 为 admin， 后 面 章节 数据 库 登 录 全 是 使 用 
admin。 如 果 需 要 使 用 匿名 用 户 ， 可 以 单 击 选 择 “Create An Anonymous Accout" £ dz 
来 创建 ， 如 图 1-46 Br. 

(15) ffs Bi | 按钮， 打开 最 后 的 “Processing configuration 〈 进 程 确认 测 
试 )” 对 话 框 ， 单 击 “Excute〈 执 行 )” 对 话 框 进入 最 后 的 配置 确认 ， 并 显示 配置 的 结 末 ， 如 
图 1-47 所 示 。 

安装 完成 后 ， 单 击 : Hz. MySQL 数据 库 的 安装 就 完成 了 。 用 上 述 的 方法 安装 完 
数据 库 后 ， 打 开 C 盘 下 的 MySQL 文件 来 ， 里面 有 个 my.ini 的 配置 文件 ， 由 于 是 默认 安 闭 所 
以 三 找到 如 下 的 代 但 : 
































#Path to the database root 
datadirz2"C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.5/Data/" 


ABUS PE AGE US S AE B1. BL Jes T c en PUE TUAE SC EIS] ics Po n] EA EITE HH. 
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同时 修改 MySQL 的 默认 字符 集 为 gpbk， 即 查找 character-set-server， 然 后 将 后 面 的 字符 集 进 
行 修改 。 


NySQL Server Instance Configuration Wizard bj NySQL Server Instance Configuration Wizard 


MySQL Server Instance Configuration MySQL Server Instance Configuration 


Configure the MySQL Server 5,5 server instance. Configure the MySQL Server 5.5 server instance. 








Please set the security options. Processing configuration ... 


J Modify Security Settings 
Prepare configuration 
Mew root password: [^ Enter the root password. Sd ep : 
(vj Write configuration file (CAMysqlimy ini) 
| root | 


n D poke 
Confirm: | | Retype the password. (9j Start service 


[ Enable root access from remote machines (V Apply security settings 


Configuration file created. 
Windows service MySQL installed. 
[ Create An Anonymous Account Service started successfully. 
This option will create an anonymous account on this server. Please Security settings applied. 
note that this can lead to an insecure system. Press [Finish] to close the Wizard. 








x Back |L ne> ] Cancel | 
图 1-46 确认 安全 设置 图 1-47 最 后 的 配置 确认 








MySQL 数据 库 并 没有 图 形 化 的 管理 接口 ， 必 须 使 用 文学 接口 输入 数据 库 语法 进行 数据 

库 的 建立 与 管理 ， 这 对 于 不 熟悉 数据 库 语法 的 人 是 一 大 困扰 。 有 人 束 帮 MySQL 设计 了 Web 

页 的 管理 接口 ， 通 过 Web 浏览 髓 就 可 以 实现 MySQL 的 各 项 管理 功能 。 管 理 MySQL 的 工 

具 比 较 多 日 比较 出 名 的 有 phpadmin、EMS MySQL 等 ， 各 种 管理 工具 都 大 同 小 异 。 这 里 介绍 

一 区 窗口 化 操作 管理 的 平台 软件 EMS MySQL Manager Lite， 这 和 套 管 理 接 口 有 目 己 的 官方 网 

站 ， 只 要 在 网 址 列 输 入 http://sqlmanager.net/products/mysql/manager/ 即 可 看 到 这 套 工 具 的 说 明 
与 介绍 (如 图 1-48 所 示 )， 并 提供 免费 
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图 1-48 打开 可 以 下 载 的 页 面 
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之 所 以 在 这 里 特别 推荐 这 个 MySQL 的 管理 软件 ， 是 因为 它 是 MySQL 官方 提供 的 
ODBC 接口 程序 ， 系 统 安 朔 这 个 程序 之 后 ， 融 可 以 通过 ODBC 来 访问 MySQL， 这 样 就 可 
以 实现 SQLServer, Access 和 MySQL 之 间 的 数据 转换 ， 还 可 以 文 持 ASP 访问 MySQL žr 
5E. "X EMS MySQL Manager Lite 的 步骤 如 下 《在 光盘 中 system 文件 夹 下 也 有 下 载 的 
安装 文件 )。 

(1) 下 载 的 文件 是 安装 文件 ， 可 以 直接 安 狼 ， 如 图 1-49 Bron. 

(2) 双击 安装 文件 打开 “Laneguage Selection (语言 选择 )” 对 话 框 ， 单 击 选择 “英语 
(美国 )” 列 选项 ， 如 图 1-50 所 示 。 
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IHP amu c) umo IND Mhon 


"05 -gd mE Ciis DD | Language Selection | 
v EY 各 到 | Select a language you would like the wizard to proceed with. 





Huy pm £5 


m) Eezccqgre 1e 1e p , . | 
gy winiTRH ES L Choose installation language: 


Ty Anetan 
o tox RI ayigleh 5 Dexia o0 ghgeh S D7eY.44cEn hr 德 知 (德国 ) 














一 一 EM5 Database Management Solutions, Inc. 





TEMA x) 


BRAN: vürie7-1 | 

















1-49 下 载 的 安装 文件 1-50 选择 安装 语言 


(3) 单 击 Next (下 一 步 ) 按钮 ， 打 开 欢 迎 界 面 如 图 1-51 所 示 。 
(4) 单 击 Next (下 一 步 ) 按钮 ， 打 开 同 意 注 册 对 话 框 ， 如 图 1-52 所 示 。 


i5 EES SQL Nanager 2007 for MySQL setup bj 5 EES SQL Nanager 2007 for MySQL setup 


Welcome to the Installation Wizard License ågreement 

Please read the following license agreement carefully. 
Welcome to the EMS SOL Manager 2007 for MySQL Setup 
program. This program will install EMS SQL Manager 2007 for 
MySQL on your computer. 





Please closely read the following license agreement. Do you accept all the terms of the following 


. . : license agreement? 
It is strongly recommended that vou exit all windows : 


programs before running this Setup program. Click Cancel to Copyright (C) 1999-2007 EMS Database Management Solutions, Inc. 

quit Setup and close any programs you have running. Click. ll rights reserved. 

Next to continue with the Setup program. 
IMPORTANT: PLEASE READ THIS AGREEMENT CAREFULLY BEFORE USING THE 
SOFTWARE. 

WARNING: This program is protected by copyright lav and 

international treaties. END USER LICENSE AGREEMENT 
EMS Database Management Solutions, Inc. ("EMS"'] agrees to provide the user ("USER") 


Unauthorized reproduction or distribution of this program, or with a copy of this software product ("SOFTWARE"), and grants the USER a limited license to 
any portion of it, may result in severe civil and criminal use the SOFTWARE. This LICENSE AGREEMENT ("LICENSE") defines what the USER may 
penalties, and will be prosecuted to the maximum extent do with the SOFTWARE, and contains limitations on warranties, liabilities and remedies. This 
possible under law. LICENSE may be revoked by EMS at any time without notice if the USER fails to comply with ~ 








EMS Database Management Solutions, Inc. 





1-51 ZRIN Pi 1-52 同意 注册 对 话 框 





(5) 单 击 选择 “Yes，Iasgree with all the terms of this license agreement (我 同意 注册 )” 复 
选 按钮 ， 然 后 再 单 击 Next (下 一 步 ) 按钮 ， 打开“Destination Folder ZII)” XUME, 
这 里 为 了 操作 和 管理 方便 ， 选 择 默认 的 安装 ， 如 图 1-53 所 示 。 

(6) 单 击 Next (下 一 步 ) 按钮 ， 打开 “Program Group“〈 添 加 到 Windows 的 组 件 )” 对 
话 框 ， 如 图 1-54 所 示 。 
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Destination Folder 


Click Nest to install the application to this folder, or click Browse to install to a 
different location. 





Select the destination folder where you want to install EMS SOL Manager 2007 for MySQL. To 
install to a different location, click Browse, and select another folder. 


Select installation folder: 








C:\Program FilesSEMSSSOL Manager for MySQL 


| 





Disk space usage 


— — EMS Database Management Solutions, Inc. - 
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Program Group 


Select the program group where the Installation Wizard will install 
application shortcuts. 





Select program group: 
EMS 


Adobe 

Apache HTTP Server 2.2 
Autodesk 

Cool Edit Pro 2.1 

CorelDRAW Graphics Suite x5 
Microsoft Silverlight 











Snaglt 7 

WinRAR 

云端 软件 平台 

工行 网 银 客 户 端 软件 
方正 0CR 世 纪 版 








v 








图 1-53 ”设置 安 闭 路径 





EMS Database Management Solutions, Inc. - 





1-54 “添加 到 组 件 ” 对 话 框 


(7) "Ri Next (下 一 步 ) 按钮 ， 打 开 “Ready to Install the Program. (准备 开始 安装 )” 对 


(8) 单 击 Next《〈 下 一 步 ) 按钮 ， 则 打开 “Setup Status (ZI EE)” oue, Jem HA 


的 安装 进度 ， 如 图 1-56 所 示 。 


意 EES SQL 下 amager 2007 for EySQL setup 


Ready to Install the Program 
The Installation Wizard is ready to install the EMS SOL Manager 2007 for 
SüL. 


X» 


Es. 


You are now ready to install EMS SOL Manager 2007 for MySQL. 


Press the Next button to begin the installation or the Back button to re-enter the installation 
information. 


EMS Database Management Solutions, Inc. 
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Setup Status 








[ «Be J[ We» ] [Cance! ] 
Kl1-55 “准备 安装 ”对 话 框 
(9) 安装 完成 后 ， 打 开 人 确认 安装 对 话 框 ， 单 击 选 择 上 和 面 的 两 个 复 选 按 钮 。 如 图 1-57 


Bia. 





Please wait. EMS SQL Manager 2007 for MySQL installation is in progress. 


If vou want to interrupt installation process, press the Cancel button. But in this case correct 
working of the program is not guaranteed. 


Copying file... 
C:\Program Files*E MSNSQL Manager for MySQL*MyM anager.exe 
[aaa — —À6À 8 ÁP —— O) 





EMS Database Management Solutions, Inc. 


图 1-56 ”提示 安装 进度 








(10) 单 击 Finish( 完 成) 按钮 ， 即 可 安装 。 由 于 设置 安装 完成 后 打开 EMS MySQL 软 
件 ， 所 以 第 一 次 运行 的 时 候 会 打开 试用 注册 对 话 框 ， 如 图 1-58 所 示 。 


15 EES SQL 下 amager 2007 for EySQL setup 


Installation Complete 


EMS SQL Manager 2007 for MySQL has been 
successfully installed. 


Press the Finish button to exit Setup program. 


Launch SQL Manager for MySQL now 
Add SQL Manager for MySQL shortcut to desktop 





[res ] 
图 1-57 确认 安装 





Unregistorod Copy 


Thank you for evaluating SQL KNanager 2007 for NySQL! ^ 


This is a 3O0-day trial version. To xake rure you do not 
receive this notification any more, you should purchase a 


Rop rstor SQ Banngeor zDD ror Cant 


Please enter the regatration Information vou received when purchasing 
SÒL Manager 2007 for My SOL. 


pA * you Ww U onu 


the necessary registration information. 
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C | MySQL 数 据 库 的 应 用 


MySQL 数据 库 和 它 的 Web 管理 接口 EMS MySQL 的 安装 与 环境 设 定 ， 都 已 经 准备 就 绪 
了 。 接 下 来 说 明 MySQL 数据 库 的 系统 环境 ， 以 及 如 何 利用 EMS MySQL 建立 与 管理 
MySQL 数据 库 。 
1. MySQL 的 目录 
在 安装 好 MySQL 之 后 ， 会 发 现 C 磁盘 张 动 左 中 多 了 一 个 MySQL 文件 夹 。 在 此 文件 夹 
PXRH—UESHaEOUPEXG, üHÉ 1-59 Pr. 
rm DER 
Tr 9:80) rm) KEA IAM 帮助 0 Aw 


QAE- O- Ø PER prex D 
地 址 (p) C: Mysql 


ERAI TEX in - data - include 
C9 创 建 一 个 新 文件 来 
将 这 个 玄 件 来 发 布 到 
e Web : i - Én Wanager 3 - share 
kg 共享 此 文件 夹 
á -o E rare ini E mu odb-heavy-. 
一 GE E 
F 5 KB | 
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本 地 磁盘 (CD) = my—medium. ini 
G 我 的 文档 E reis | EI rans TA 
g x: s m 


q 我 的 电脑 
&j 网 上 邻居 











13 个 对 象 
图 1-59 ”完成 后 的 MySQL 文件 夹 
这 些 目 录 文 件 夹 的 说 明 如 表 1-2 PTR. 


表 1-2 目录 文件 夹 的 说 明 




















目录 名 称 m OX 5 Hx 
bin 存放 主要 的 程序 与 工具 程序 ， 如 mysql. mysqladmin 等 程序 
dus md vaa 以 后 建 好 的 数据 库 和 MySQL. 系统 本 身 内 建 的 数据 库 都 存放 在 这 
YE 
include 用 于 放置 MySQL 所 有 的 .h 文件 
lib 存放 驱动 .dll 文件 和 .lib 文件 
share 存放 主要 设 定 文件 与 记录 文件 





2. 用 EMS MySQL Manager 管 理 MySQL 

下 和 面 来 说 明 如 何 用 EMS MySQL Manager 实际 操作 ， 建 立 与 管理 MySQL 数据 库 。 要 建 
也 一 个 名 为 test_db 的 MySQL 数据 库 以 及 新 增 name 数据 表 ， 操 作 步 骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", 进入 MySQL 数据 库 的 管理 接 
口 ， 如 图 1-60 所 示 。 
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K SQL Nanager 2007 for MySQL 
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1-60 3A MySQL 数据 库 的 管理 接口 


(2) 选择 亲 单 栏 中 Database FHH “Create Database (创建 数据 库 )” 命 令 ， 打 开 
“Register Data base Wizard (注册 数据 表 )” 对 话 框 ， 对 话 框 的 设置 如 图 1-61 所 示 。 这 里 要 和 输 
入 表面 数 据 库 安 闭 时 的 黎 但 admin. 


Kegister Database Wizard 
Register Database 
Specify the connection parameters 
Welcome ta the Register Database wizara! 


This wizard allaovvz vou to set the connection parameters for the selected databases 
only once, giving vou the possibility ta connect them quickly afterwards. 


This wizard will quide you through the process of setting the connection parameters, 
selecting databases, and customizing their specific options. 


Host name localhost 
User name 


Pazzweord 


[] Register a single database 
[ | Use tunneling 


Tunneling 
SSH tunneling HTTP tunneling 





1-61. 开始 独 建 数据 库 


(3) Hal Next〈 下 一 步 ) 按钮 ， 在 下 和 面 的 对 话 框 中 ， 选 择 默 认 的 MySQL 数据 库 ， 再 单 
市 添加 按钮 国 ， 如 图 1-62 所 示 。 





Kegister Database Wizard 
Register Database 


Select databases to register 


Available databases Selected databases 
information schema ms xul 


performance schema 





图 1-62 添加 了 预先 设置 的 默认 数据 库 


(4) 单 击 Next( 下 一 步 ) 按钮 ， 打 开 “Resister Database (注册 数据 库 )” 对 话 框 ， 设 置 
的 时 候 要 注意 把 Font charset 选择 为 GB 2312, CHARSET， 表 示 设 置 为 简体 中 文 ， 如 图 1-63 
Br. 





Eegister Database Fizard 
Register Database 


Set some specific options Far registered database[s] and click the Finish button 


Alas 


myzal an localhost 


Database 


Database alias myzal on localhost 


Client charset utta 


ka 
Font charset GB2312 CH&RSET bal 


Refresh objects on connection [ ]Interactive mode 

F] Login prompt before connection 

[ |Use compression protocol [] Autoconnect an startup 
Keep connection alive [| Disable transactions 
[C] Use SSL protocol 





图 1-63 设置 数据 库 属 性 
(5) 最 后 单 击 Finish (完成 ) 按钮 ， 完 成 后 的 效果 如 图 1-64 所 示 。 
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1-64 连接 上 数据 库 


这 样 束 完成 了 数据 库 MySQL 的 狐 增 工作 ， 接 下 来 就 建立 网 页 数据 所 需 的 数据 表 。 狐 增 
的 操作 步骤 如 下 。 

(1) 建立 数据 库 MySQL 后 ， 要 把 这 个 数据 库 连 接 上 ， 单 击 工具 栏 上 的 “Connect to 
Database (连接 )” 按 钮 总 ， 将 其 连接 ， 如 图 1-65 所 示 。 
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1-65 连接 数据 库 
(2) 连接 上 以 后 ， 将 选择 Table 进行 狐 增 数据 表 ， 如 图 1-66 所 示 。 
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: ocalhostimysql on localhost!Tables:columns z 

: Field Type | 
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1-66 ”新 增 数据 表 


G) 数据 库 右 方 画 面 会 出 现 新 建 数 据 表 (Table) 的 设 定 区 域 ， 单 击 “Create New Table (6/J 
建新 表格 )” 选 项 ， 单 击 后 即 可 建立 一 个 数据 表 ， 含 有 “Table”“Fields”“DDL”3 个 选项 
卡 ， 先 在 “Table” 中 输入 数据 表 名 “name” 如 图 1-67 Pr. 





: New Table — [mysql on localhost] 


Table Properties 
E mysql on localhost [mysql] v 
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1-67 建立 的 数据 表 


(4) 在 “Fields” 选 项 卡 中 ， 输 入 数据 域名 以 及 设 定 数据 域 位 的 相关 数据 ， 如 图 1-68 
所 示 。 








QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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1-68 WU E “Fields” 











(5) 如 果 要 设 定 字段 的 属性 ， 例 如 学 生 编写 Id 要 设 定 目 动 编写 的 属性 ， 那 么 只 要 利用 也 


标 双 击 字 段 名 称 ， 丈 会 弹出 字段 的 编辑 方块 ， 在 这 里 可 以 义 选 “Not null PAE)” 


“Autoincrement〈 目 动 编号 )”“Primary key〔 关 键 字 )” 的 复 选 按钮 选项 


Br. 


Edit field 'ID' 
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页 ， 设 置 如 图 1-69a, b 


Edit field 'name' 
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图 1-69 字段 属性 的 设 定 





ies 解决 PHP 与 MySQL 乱 码 问题 


在 初次 配置 PHP 运行 文 持 MySQL 后 ， 对 于 初学 者 来 说 ， 通 上 中 文 乱 但 是 开始 学 习 时 过 
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到 的 第 一 个 问题 ， 本 节 将 重点 介绍 如 何 解决 这 个 问题 。 

般 说 来 ， 乱 人 码 的 出 现 有 两 种 原因 。 首 先是 由 于 编码 (Charset) 设置 错误 ， 导 致 浏览 句 
以 错误 的 编码 来 解析 ， 从 而 出 现 了 满 屏 乱 七 八 糟 的 符号 ， 不 能 正常 显示 中 文 ， 其 次 是 文件 被 
以 错误 的 编码 打开 ， 然 后 保存 ， 比 如 一 个 文本 文件 原先 是 GB2312 编码 的 ， 却 以 UTF-8 编码 
打开 再 保存 。 

要 解决 上 述 乱 码 问 题 ， 首 先 需 要 知道 开发 中 哪些 环节 涉及 了 编码 。 

(OD 文件 编码 被 修改 。 指 的 是 页 面 文件 Chtmb .php 等 ) 本 身 是 以 何 种 编码 来 保存 的 。 
记事 本 和 Dreamweaver 在 打开 页 面 的 时 候 会 目 动 识别 文件 编码 ， 因 而 不 太 会 出 问题 。 而 
ZendStudio 却 不 会 目 动 识别 编码 ， 它 只 会 根据 首选 项 的 配置 ， 固 定 以 某 种 编码 打开 文件 ， 如 
果 一 旦 用 错误 编码 打开 文件 ， 当 做 了 修改 之 后 保存 时 ， 乱 码 就 出 现 了 。 

(2) 页 面 声明 编码 不 统一 。 在 HTML 代码 HEAD 里 面 ， 可 以 用 <meta http-equiv= 
"Content-Type" content-" text/html; charset=" XXX" /> 来 告诉 浏览 器 网 页 采用 了 什么 编 公 。 目 前 
中 文 网 站 开发 中 XXX 主要 用 的 是 GB2312 和 UTF-8 两 种 编码 。 

(3) 数据 库 连接 编码 不 正确 。 指 的 是 进行 数据 库 操作 的 时 候 ， 以 哪 种 编码 与 数据 库 传 输 
数据 ， 这 里 需要 注意 的 是 不 要 与 数据 库 本 喘 的 编码 混 消 ， 比 如 MySQL 内 部 默认 是 latinl 编 
ti, EEL MySQL 是 以 latinl 编码 来 存储 数据 ， 以 其 他 编码 传输 给 MySQL 的 数据 会 被 
转换 成 latinl 编码 。 

知道 了 网 站 开发 中 哪些 地 方 涉及 到 了 编码 ， 也 就 知道 了 产生 乱码 的 原因 。 下 面 是 一 些 常 
见 的 错误 情况 与 解决 方法 。 

问题 一 : 数据 库 采 用 UTFS 编码 ， 而 页 面 声明 编码 是 GB2312. 

这 是 最 常见 的 产生 乱码 的 原因 。 这 时 候 在 PHP 脚本 里 面 直 接 SELECT 数据 出 来 的 就 是 
乱码 ， 需 要 在 查询 前 先 使 用 mysql_query("SET NAMES GBK") 来 设置 MySQL 连接 编码 ， 保 
证 页 面 声明 编码 与 这 里 设 定 的 连接 编 公 一 人 改 (GBK 是 GB2312 的 扩展 )。 

如 果 页 面 是 UTF-8 编码 的 话 ， 可 以 用 mysql query"SET NAMES UTF8")， 注 意 是 
UTFS 而 不 是 一 般 用 的 UTF-8。 假 如 页 面 声 明 的 编码 与 数据 库 内 部 编码 一 怪 则 可 以 不 设 定 
连接 编码 。 

例如 ， 本 书 的 购物 车 系统 的 数据 库 连 接 时 设置 的 编码 规则 如 下 。 













































































<?php 
$conn=mysql_connect("localhost","root","admin") or die(" 数 据 库 服 务 器 连接 错误 ".mysql_ 


error()); 





R— wv 


mysql query("set character set gb2312"); 
mysql query("set names gb2312"); 
2» 


MySQL 的 数据 输入 /输出 比 上 面 讲 的 更 复杂 一 些 ，MySQL 配置 文件 myini 中 定义 了 两 
个 默认 编码 ， 分 别 用 [client] 里 的 default-character-set 和 [mysqld] 里 的 default-character-set 来 设 
定 默 认 时 候 客 户 问 连接 和 数据 库 内 部 所 采用 的 编码 。 上 和 面 指定 的 编码 其 实 是 MySQL %7 iim 
连接 服务 器 时 候 的 命令 行 参 数 character_set_client， 来 告诉 MySQL 服务 器 接收 到 的 客户 病 数 
据 是 什么 编码 的 ， 而 不 是 采用 默认 编码 。 
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问题 二 : 页 面 声明 编 但 与 文件 本 续 纲 码 不 一 致 。 

这 种 情况 很 少 发 生 ， 因 为 如 采编 码 不 一 致 ， 美 工 做 页 面 的 时 候 在 浏览 器 看 到 的 残 是 乱 
人 码 。 蝎 多 时 候 是 发 布 以 后 修改 一 些小 BUG， 由 于 以 错误 编码 打开 页 面 然后 保存 导致 的 乱 
5j: 或 者 是 用 菜 些 FTP 软件 直接 在 线 修改 文件 ， 比 如 CuteFTP， 由 于 软件 编码 配置 错误 而 叶 
伊 转 换 错 了 编码 。 

问题 和 三， 服务 右 Apache 设 趾 了 服务 器 全 局 的 默认 编码 。 

一 些 租 用 虚拟 主机 的 朋友 ， 明 明 上 述 3 项 编码 都 设置 正确 ， 但 还 是 有 乱码 。 比 如 ， 网 页 
是 GB2312 编码 的 ， 正 等 浏览 器 打开 却 总 是 识别 成 UTF-8， 网 页 HEAD 里 面 已 经 声明 是 
GB2312 了 ， 手 动 修改 浏览 器 编码 为 GB2312 后 页 面 显示 正常 。 产 生 原 因 是 服务 器 Apache 设 
定 了 服务 器 全 局 的 默认 编码 ， 在 httpd.conf 里 而 加 了 AddDefaultCharset UTF-8。 这 时 候 服务 
ERHI HTTP 给 浏览 器 ， 其 优先 级 比 页 面 里 声明 编码 高 ， 目 然 浏 览 器 就 发 生 识别 错 
误 。 解 决 办 法 有 两 个 ， 管 理 员 在 配置 文件 目 己 的 虚 机 里 加 上 一 条 AddDefaultCharset GB2312 
来 复 辣 全 局 配置 ， 或 者 在 目 己 目录 的 .htaccess 里 配置 。 



























































e 42 PHP 编 程 基础 


PHP 是 一 种 易于 使 用 的 服务 器 端 脚本 语言 ， 只 需要 很 少 的 编程 知识 就 能 使 用 PHP. 建立 一 个 真 
正 具有 交互 功能 的 Web 站 点 。 对 于 初学 者 而 言 ， 是 需要 花 一 些 功 夫 去 掌握 PHP 的 编程 基础 。 本 书 
以 最 简单 易学 的 方法 介绍 一 些 PHP 的 基本 语法 ， 包 括 变 量 、 常 量 、 运 算 符 、 控 制 语句 以 及 数组 
等 ， 通 过 学 习 这 些 基础 知识 使 谈 者 能 更 深入 地 了 解 PHP。 











MATIE E 


要 掌握 以 下 知识 点 : 


y 在 Dreamweaver 进行 PHP 开发 平台 的 搭建 


© PHP 程序 编写 的 基础 知识 

(—7 掌握 PHP 表单 变量 的 使 用 

© PHP 程序 中 常量、 变量 、 表 达 式 以 及 遂 数 的 基础 
O 重点 掌握 PHP 和 MySQL 数据库 的 操作 





€2u QUIT 





在 Dreamweaver 中 建立 PHP 执 行 环境 
Dreamweaver CS 5.5 这 套 软 件 提供 了 网 站 开发 的 整合 性 环境 ， 它 可 以 文 持 不 同 服务 器 技 | 
术 ， 如 ASP, PHP. JSP 等 ， 建 立 动态 文 持 数据 库 的 网 络 应 用 程序 ， 同 时 也 能 让 不 情 程 序 代 
码 的 网 站 设计 人 员 或 初学 者 ， 能 在 不 用 捅 写 程 序 代 码 的 情况 下 ， 学 习 动 态 网 页 技术 的 设计 。 
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在 开始 制作 网 站 之 前 ， 还 要 了 解 在 Dreamweaver CS 5.5 中 的 网 页 设计 和 发 布 流程 。 它 可 
以 分 为 如 下 5 个 主要 步骤 。 

第 一 步 : 规划 网 站 站 点 

需要 了 解 网 站 建设 的 目的 ， 确 定 网 站 提供 的 服务 以 及 针对 的 是 什么 样 的 访问 者 ， 以 确定 
网 页 中 应 该 出 现 什 么 内 容 。 

第 二 步 : 建立 站 点 的 基本 结构 

Dreamweaver CS 5.5 可 以 在 本 地 计算 机 上 建立 出 整个 站 点 的 框架 ， 并 在 各 个 文件 夹 中 合 
理 地 安置 文档 。Dreamweaver CS 5.5 可 以 在 站 点 窗口 中 以 两 种 方式 显示 站 点 结构 ， 一 种 是 目 
录 结 构 ， 田 一 种 是 站 点 地 图 。 可 以 使 用 站 点 地 图 方式 快速 构建 和 查看 站 点 原型 。 一 旦 创建 了 
本 地 站 点 并 生成 了 相应 的 站 点 结构 ， 创 建 了 即将 进一步 编辑 的 各 种 文档 ， 束 可 以 在 其 中 组 织 
文档 和 数据 。 

第 三 步 : 实现 所 有 页 面 的 设计 

建立 站 点 之 后 ， 进 入 Dreamweaver CS 5.5 软件 中 ， 开 始 进 行 页 面 的 版 面 规 划 设 计 ， 利 用 
强大 的 编辑 设计 功能 实现 各 种 复杂 的 表格 ， 然 后 再 组 织 页 面 内 容 。 为 了 你 持 页 面 的 统一 风格 
可 以 利用 模板 来 快速 生成 文档 。 

第 四 步 ， 充实 网 页 内 容 

在 创建 了 基本 版 面 页 面 后 ， 束 要 往 框 染 里 填充 内 容 。 在 文档 窗口 中 合适 的 地 方 ， 可 以 输 
入 文字 和 其 他 资源 ， 例 如 图 像 、 水 平 线 、Flash 插件 和 其 他 对 象 等 ， 大 多 可 以 通过 插入 面 版 
或 插入 沫 单 来 完成 插入 。 

第 五 步 : 发 布 和 维护 更 新 

在 站 点 编辑 完成 后 ， 需 要 将 本 地 的 站 点 同位 于 Internet 服务 器 上 的 远 问 站 点 关联 起 来 ， 
把 本 地 设计 好 的 网 站 内 容 传 到 服务 器 上 ， 并 注意 后 期 的 及 时 更 新 和 维护 。 


本 地 站 点 网 站 文件 夹 规划 


在 制作 网 站 之 前 ， 首 先是 把 设计 好 的 网 站 内 容 放 置 在 本 地 设计 计算 机 的 便 盘 上 ， 为 了 方 
便 站 点 的 设计 及 上 传 ， 设 计 好 的 网 页 都 应 存储 在 Apache 服务 需 的 安 猜 路 径 下 《如 本 书 的 路 
径 为 C:\Apache\htdocs 目录 下 )， 再 用 合理 的 文件 夹 来 管理 文档 。 在 本 地 站 点 规划 的 时 候 ， 应 
该 注意 如 下 的 操作 规则 。 
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1. 设计 合理 的 文件 夹 

在 本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 
然后 在 其 中 再 创建 多 个 子 文件 严 ， 最 后 将 文档 分 类 存储 到 相应 的 文件 夹 下 。 

例如 ， 可 以 在 images 的 文件 夹 中 放置 网 站 页 面 的 图 片 ， 可 以 在 aboutus 文件 夹 中 放置 用 
于 介绍 公司 的 网 页 ， 可 以 在 service 文件 夹 中 放置 天 于 公司 产品 方面 的 网 页 。 如 图 2-1 所 示 
是 一 个 大 型 电子 商务 网 站 规划 建立 的 文件 夹 文档 。 


QAE- O- Pus Drix [Dg 


地 址 年 ) | 需 C: Apachevhtdocsvshop 
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C9 创建 一 个 新 文件 来 
2] 将 这 个 文件 夹 发 布 到 
E 共 训 此 文件 夹 








EXP finddd php 
' Script 


P 
</> 6 KB 
EN futi on. php 
Hr Script 
<I> 1 KB ih 


EXP hizhfind.php 
PHP Script 


(5 iu 


PHP logout. php 
Hr Script 
(5 im 

















= p. ER 0 aha WFR aure 
48 个 对 象 216 KB Y 我 的 电脑 





图 2-1 网 站 在 本 地 硬盘 上 的 文件 夹 建立 


2. 设计 合理 的 文件 名 称 

网 站 建设 由 于 要 生成 的 文件 很 多 ， 所 以 经 常 要 用 合理 的 文件 名 称 。 这 样 操 作 的 目的 其 一 
是 为 了 方便 在 网 站 的 规模 变 得 很 大 时 ， 可 以 进行 修改 更 狐 ;， 其 二 也 是 为 了 方便 浏览 者 在 看 了 
网 页 的 文件 名 ， 束 能 够 知道 网 页 所 要 表述 的 内 容 。 

在 设计 合理 的 文件 名 时 要 注意 以 下 几 点 。 

(OD 尽量 使 用 短文 件 来 命名 。 

(2) 应 该 避免 使 用 中 文 文件 名 ， 因 为 很 多 Internet 服务 器 使 用 的 是 英文 操作 系统 ， 不 能 
对 中 文 文件 名 提供 很 好 的 文 持 ， 而 且 浏览 网 站 的 用 户 也 可 能 使 用 英文 操作 系统 ， 中 文 文件 名 
同样 可 能 导致 浏览 错误 或 访问 失败 。 

(3) 建议 在 构建 的 站 点 中 ， 全 部 使 用 小 写 的 文件 名 称 。 很 多 Internet 服务 占 采 用 UNIX 
操作 系统 ， 它 是 区 分 文件 的 大 小 写 的 。 

特别 注意 : 

在 PHP 建立 的 站 点 文件 夹 及 文件 名 一 定 要 使 用 英文 名 称 或 者 数字 名 称 ， 不 要 使 用 中 文 
名 称 来 命名 ， 否 则 会 导致 Apache 服务 器 不 能 正常 支持 该 站 点 。 


3. 设计 本 地 和 远程 站 点 为 相同 的 文件 结构 
设计 本 地 和 远程 站 点 为 相同 的 文件 结构 是 指 在 本 地 站 点 中 规划 设计 的 网 站 文件 结构 要 同 
上 传 到 Internet 服务 器 中 被 人 浏览 的 网 站 文件 结构 相同 。 这 样 在 本 地 站 点 上 的 文件 夹 和 文件 上 
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的 操作 ， 都 可 以 同 远 程 站 点 上 的 文件 夹 和 文件 一 一 对 应 。Dreamweaver CS 5.5 将 整个 站 点 上 传 
到 Internet 服务 占 上 ， 部 可 以 保证 远程 站 点 是 本 地 站 点 的 完整 的 拷贝 ， 方 便 浏览 和 修改 。 


建立 流畅 的 浏览 顺序 DMA 


在 网 站 创建 的 时 候 首 先 要 考虑 到 网 站 所 有 页 面 的 浏览 顺序 ， 注 意 主 次 页 面 之 间 的 链接 是 
否 流畅 。 如 果 采 用 标准 统一 的 网 页 组 织 形式 ， 可 以 让 用 户 轻 松 上 自如 地 访问 每 个 想 要 访问 的 网 
页 。 这 样 能 提高 浏览 的 兴趣 ， 加 大 网 站 的 访问 量 。 建 立 站 点 的 浏览 顺序 ， 要 注意 如 下 几 个 方 
— 

一 : 每 个 页 面 建 立 首 页 的 链接 

diio —— 
束 可 以 保证 用 户 在 不 知道 自己 目前 位 置 的 情况 下 ， 快 速 返回 到 首页 中 ， 重 狐 开 始 浏 览 站 点 中 
其 他 内 容 。 

第 二 : 建立 网 站 导航 

应 该 在 网 站 任何 一 个 页 面 上 建立 网 站 导航 ， 通 ; 过 导航 提供 站 点 的 简明 目录 结构 ， 引 叶 用 
户 从 一 个 页 面 快速 进入 到 其 他 的 页 面 上 。 

第 三 : 突出 当前 页 位 置 

在 网 站 页 面 很 多 的 情况 下 ， 往 往 需要 加 入 当前 页 在 网 站 中 的 位 置 说 明 ， 或 者 是 加 入 说 明 
的 主题 ， 以 帮助 浏览 者 了 解 目 前 所 处 的 访问 位 置 。 如 果 页 面 髓 套 过 多 ， 则 可 以 通过 创建 “前 
进 ” 和 “后 退 ” 之 类 的 链接 ， 来 帮助 浏览 者 进行 浏览 。 

第 四 : i ei 

对 于 一 些 禹 数据 库 的 网 站 ， 还 应 该 给 浏览 者 提供 搜索 的 功能 ， 或 是 给 浏览 者 提供 索引 检 
ME MUR E 

第 五 : 必要 的 信息 反馈 功能 

网 站 建设 发 布 后 ， 都 会 存在 一 些小 问题 ， 从 浏览 者 那里 及 时 获取 对 网 点 的 意见 和 建议 是 
非常 重要 的 。 为 了 及 时 从 用 户 处 了 解 到 相关 信息 ， 应 该 在 网 页 上 提供 用 户 同 网 页 创作 者 或 网 
站 管理 员 的 联系 途径 。 常 用 的 方法 是 建立 留言 板 或 是 创建 一 个 E-mail 超级 链接 ， 帮 助 用 户 快 
速 将 信息 反馈 到 网 站 中 。 


_ 定 义 本 章 PHP 网 页 测试 网 站 


Dreamweaver 要 开发 网 站 之 朋 ， 一 定 要 先 定 义 网 站 ， 利 用 Dreamweaver CS 5.5 *x& ri" 
一 “管理 站 点 ”命令 来 进行 管理 。 使 用 Dreamweaver CS 5.5 进行 网 页 布局 设计 时 ， 首 先 需 要 
FH E Sons ea n] SEXE NC Es o 

定义 本 章 所 要 学 习 的 PHP. 语法 网 页 的 站 点 具体 操作 步骤 如 下 。 

(1) 首先 在 CAMApacheMtdocs 路 径 下 建立 php 文件 夹 ， 如 图 2-2 所 示 ， 本 章 所 有 建立 的 
PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 

(2) 打开 Dreamweaver CS 5$.5， 选 择 来 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 2-3 Br. 
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C:\Apache\htdocs 
TF 编辑 人 下) EEM ka IAM # 0) Ld 


QAE- O A PRR (oxtX m 
地 址 Q) [4 C: SÁpachehhtdocs x] 转 到 


文件 和 文件 卖 任务 Q) S EIAS o p siii 


m] 至 命名 这 个 文件 到 «bis 
Gy 移动 这 个 文件 来 

TARDER 

Q 将 这 个 文件 来 发 到 


Eg 共享 此 文件 夹 


A 以 电子 邮件 形式 发 送 该 
辫 件 夹 内 的 文件 


K 删除 这 个 交 件 夹 











2-2 建立 站 点 文件 夹 php 





Dw sim "| O) O sw COEM 
xo «euo s3Wwo SAN wm) w) ic) & EGW "ho | SoSe 


t = Tt. ne 


ECET LL E ER: 


TO Gnuscucor x. 


打开 最 近 的 项 目 


x ph ob og EE d 


o 
U 
" 


RIRA Adobe Cre mi ve Suite 5 Te 
fresium ERE Adobe Dreamweavert CSS 
Frotessienal, 


v B: IEN apem 
vag á Bnw 














2-3 “管理 站 点 ”对 话 框 


(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建 ” 按 钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ” php. 

“本 地 站 点 文件 来” ”C:\Apache\htdocs\php\。 

如 图 2-4 Bras. 











MaRa php 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 和 到 web 上 的 服务 器 上 的 远程 文件 夹 。 











您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 来 和 名 称 。 
站 点 名 称 : 
本 地 站 点 识 件 夹 ; | Capachehtdocs\php' 5 





2-4 建立 php 站 点 


(4) 单 击 列 表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 上 |， 打开 “基本 ” 


选项 卡 ， 进 行 如 图 2-5 所 示 的 参数 设置 。 
“RIAA”: phpe 
“连接 方法 ” 本地/ 网络 。 
“服务 右 文 件 夹 ”CC:\Apache\htdocs\。 
“Web URL”: http://127.0.0.1/。 


Aak php 














Web URL: | http:j/127.0.0.1/ 





2-5 设置 “基本 ”选项 卡 





(50 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 步 
信息 ” 复 选 按钮 ， 在 “服务 需 模 型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 








7PHP-^ 





的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 2-6 所 示 。 


靖 点 设置 对 象 php 





远程 服务 器 





M 维护 同步 信息 
O 保存 时 自动 将 玄 件 上 传 到 服务 器 
O 启用 交 件 职 出 功能 

[Vl 打开 文件 之 前 取出 


取出 名 称 ; 
电子 邮件 地 址 : 
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2-6 设置 “高 级 ”选项 卡 


(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 勾 选 “测试 ” 复 选 按钮 ， 
如 图 2-7 所 示 。 


站 点 设置 对 象 php 


BE 您 将 在 此 位 置 选择 学 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


* ”高 级 设置 








注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 
布 页 面 ， 您 只 需 定 多 一 个 远程 服务 器 即 可 。 





地 址 | 连接 | 远程 | 测试 | 
Cjapacheljhtdocs 本 地 |/ 网络 [V M 








2-7 设置 “服务 器 ”参数 
单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 





才 所 设置 的 站 点 了 。 由 于 是 在 本 机 测试 PHP 网 页 ， 因 此 不 需要 设 定 “远程 信息 ”。 设 定好 
“本 地 信息 ”与 “测试 服务 器 ”之 后 ， 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 杠 ， 这 样 
束 完 成 了 Dreamweaver CS 5.5 测试 PHP 网 页 的 网 站 环境 设置 。 








PHP 程 序 编写 基础 


如 果 读 者 对 ASP 或 者 JSP 有 所 了 解 ， 应 该 知道 在 编写 这 些 网 页 程序 时 ， 可 以 将 HTML 
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标记 与 这 些 动态 语言 代码 混合 到 一 个 文件 中 。 然 后 使 用 特殊 的 标识 (符号 “<%%>”) 将 两 
者 区 别 开 来 。PHP 也 是 如 此 ， 可 以 与 HTML 标记 共存 ，PHP 提供 了 多 种 方式 来 与 HTML 标 
记 区 别 ， 用 户 可 以 根据 自己 的 喜好 选择 一 种 ， 也 可 以 同时 使 用 几 种 。 本 小 节 将 介绍 PHP 的 
基础 程序 结构 ， 包 括 输出 和 注释 的 方法 。 


zu PHP 程 友 结 构 


























PHP 语句 与 Perl 和 C 一样， 结构 比较 严谨 ， 需 要 在 每 条 语句 后 使 用 分 号 “;” 来 作为 结 
束 ， 而 且 对 语句 中 的 大 小 写 敏感 。 

第 用 的 方式 有 如 下 3 种 。 

方法 1: PHP 标准 结构 (推荐 ) 











<?php 
Echo "hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程序 !": 
T» 


方法 2: PHP 的 简短 风格 (需要 设置 php.ini) 
<?Echo "hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程序 1";?> 
方法 3: PHP 的 SCRIPT 风格 (元 长 的 结构 》 
<script language="php">echo"hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程序 !"; </script> 


3 种 方法 输出 的 结果 是 一 样 的 ， 在 Dreamweaver 里 编辑 后 输出 的 结果 如 图 2-8 所 示 。 





A PHP 程 序 结 档 - 了 icrosoft Internet Explorer 
WHr ”编辑 人 下) EEV KEA ILA) 帮助 0 


QmB-O-[9|[2 (5 Sk gumx Olea- REGAL 
地 址 0) E] http: //127. 0.0. 1/php/PHP/PHP. hello. php -marmer MRa SE Qc E 








PHRB+HF 


PHP 标 准 结 攀 推荐 ) 

<?php 

echo “hello, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !: 
T> 


PHP 的 简短 风格 需要 设置 php. ini) 
<? echo “hello, 你 好 ， 这 是 我 的 第 一 个 FHP 程序 1":; ?> 


PHPH SCRIPTAE (TERE) 
<script language-"php'5 echo“hel1lo, 你 好 ， 这 是 我 的 第 一 个 PHP 程 序 !”; </script> 


hello ,你 好 ， 这 是 我 的 第 一 个 PHP 程 序 ! 








DES 


图 2-8 输出 结 


实际 开发 时 ， 第 1 种 和 第 2 种 是 最 常用 的 方法 ， 即 使 用 小 于 号 加 上 问号 之 后 跟 PHP 代 
码 ， 在 程序 代码 的 最 后 ， 使 用 问号 及 大 于 写作 为 结束 ， 而 第 3 种 方法 有 点 类 似 于 JavaScript 

















"P zr 


的 编写 方式 。 
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T PHP 输 出 结果  ， 


PHP 输出 所 有 参数 可 以 用 echo0 命 令 ，echo0 不 是 一 个 函数 〈 它 是 一 个 语言 结构 )， 因 此 
不 一 定 要 使 用 小 括号 来 指明 参数 ， 单 引号 、 双 引号 都 可 以 。echo0 不 像 其 他 语言 结构 表现 得 
不 像 一 个 函数 ， 所 以 不 能 总 是 使 用 一 个 函数 的 上 下 文 。 另 外 ， 如 果 想 给 echo0 传 递 多 个 参 
数 ， 那 么 就 不 能 使 用 小 括号 。 

提示 : 

也 可 以 使 用 printO0 命 令 来 实现 ， 但 echo) 2 F6 printO 函 数 快 一 点 。 

举例 用 PHP 输出 语句 ， 包 括 HTML 格式 化 标签 ， 如 图 2-9 所 示 。 


Zi PHP 语 句 萄 出 — Microsoft Internet Explorer 加 回国 
TFP $80) S50 REA IA) 帮助 0 ao 


QAE- O- [nie sk wx e 2-35 « 
地 址 Q) | 外 http: //127.0.0. l/php/PHP/PHP echo. php peaa HE Q snaeIt [er 








PHP 基 础 语法 实例 返回 


PHP 代 码 + 往 释 


<?php 
echo “<p RA RH A3 SEXE E$8o Xp"; 


(AD Internet 





2-9 4E echo 输出 字符 





Lus. PHP 程序 注释 


PHP 中 可 以 使 用 以 多 种 风格 的 注释 方式 。 
/ 第 1 种 PHP 注释 适合 用 于 多 行 */ 
// 第 2 种 PHP 注释 适合 用 于 单行 
# 第 3 种 PHP 注释 适合 用 于 单行 


PHP 注释 和 C、C++ 和 Shell 的 注释 风格 一 样 ， 以 认为 开始 ，*/ 为 结束 ， 例 如 : 





<?php 

/* 

注释 : 关于 本 段 程序 的 说 明 

该 段 程 序 主 要 用 于 建立 数据 库 的 连接 .…. 
ii 




















425 QUII, 


?> 

单行 注释 (有 /和 # 这 两 种 ): 
<?php 
echo "说 明 "; /得 出 说 明 二 字 
echo "说 明 ";# 输 出 说 明 二 学 


?> 


注意 一 下 ， 注 释 符 号 只 有 在 <?php ?> 里 才 会 起 到 应 有 的 效果 。 


Section 


空 制 动态 输出 字符 


在 实际 的 网 页 设计 过 程 中 ， 单 使 用 echo0 函 数 命令 并 不 能 满足 实际 的 应 用 ， 如 需要 和 输出 
随机 的 数字 ， 控 制 字符 串 的 大 小 号 以 及 一 坚 特 殊 的 字符 处 理 等 音 用 操作 ， 都 可 以 通过 调用 相 
应 的 函数 命令 加 以 实现 。 


esu PHPERZARBS S Fj 


如 果 要 实现 相应 的 字符 控制 就 需要 调用 相应 的 函数 命令 ， 在 PHP 编程 中 调用 相应 的 也 
数 还 是 比较 简单 的 ， 如 使 用 rand0 函 数 来 产生 一 个 随机 数字 《范围 是 0 一 100 )。 
<?php 


echo rand(0,100); 
?> 


刷新 便 可 看 到 输出 结果 的 变化 ，rand 函数 中 的 0 和 100 为 指定 给 rand 函数 的 参数 ， 





























前 面 的 0 就 意味 着 最 小 可 能 出 现 的 数值 为 零 ，100 则 意味 着 最 大 可 能 出 现 的 数值 为 100, 
如 图 2-10 所 示 。 很 多 函数 部 有 必 选 或 是 可 选 的 参数 。 


2 i — Nicrosoft Internet Explorer 

Pic) AB) do umo) IB) Woo 

Qae- O- ado PS «mx 6 5-.[3«c 

IRIE D) AE] http: //121.0 0. 1/php/PHP/PHP Function php -HAIRAN VEPS ER Qsec p 


PHP 基 础 语法 实例 返回 


PHPICGIS ERE 


Arnd dj tok 4 — 1 PRHLIESE (范围 是 0 到 100); 
?php 
echo rand(0, 100) 


— TT rand t d: 030 10055 TRE £i randifi 68 46, 前 画 的 0 就 意味 着 最 小 可 
iem ante di S". 100 则 意味 看 业 大 可 能 出 现 的 数值 为 100， 很 多 函 钠 都 有 必 选 或 是 可 选 的 湖 雏 。 





图 2-10 输出 随机 函数 的 结果 











"s zm 


232 截 去 字符 串 首尾 : 





使 用 trim 函数 可 以 返回 去 除 字 符 串 string 首尾 的 空白 字符 后 的 字符 串 。 
语法 : string trim(string str); 
返回 值 : 字符 串 
函数 种 类 : 资料 处 理 
在 使 用 来 目 HTML 表单 信息 之 前 ， 一 般 都 会 对 这 些 数据 做 一 些 整理 。 
<?php 
/请 理 字 符 串 中 开始 和 结束 位 置 的 多 余 空 格 
$name =" 12356789 "; 
$name = trim($name); 

















echo $name; 
?> 


运行 的 结 末 可 以 将 前 后 的 空 日 去 除 。 


于 于 格式 化 输出 字符 | 





nl2brO 函 数 可 以 将 换行 字符 转换 成 HIML 换行 的 <br> 指 令 。 
语法 : string nl2br(string string); 
返回 值 : 字符 串 
函数 种 类 ， 资料 处 理 
举例 如 下 : 
<?php 
$str = "今天 的 天 气 特 别 好 ， 心 情 也 不 错 
， 决 定 去 学 校 足 球场 ， 好 好 的 足 一 场 球 。"; 
echo $str; 
echo "<br />": 
echo nDbr(Sstr); 
7» 


输出 的 结果 如 图 2-11 所 示 。 














ZU 打印 格式 化 输出 j 


PHP FF printfO 结 构 在 实现 echo 功能 的 同时 能 返回 值 (True EX False， 是 合成 功 )， 使 


用 printtO 可 以 实现 更 复杂 的 格式 。 





语法 : int printf(string format, mixed [args]...); 
返回 值 : 整数 
函数 种 类 : 资料 处 理 

<?php 

$num = 12.8; 
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| € Dp 5B 5 s 


(PHP 编程 基础 l 


汉 格式 化 萄 出 = Nicrosoft Internet Explorer TAR) 
HFT 编辑 区 ) 查看 WW) 收藏) IAM $B500 | Ay 


ORE- O- NAOR kR e A-R BE 
地 址 0) |] http://127. 0.0. 1/php/PHP/PHP_nl2br. php < 输入 关键 词 搜索 MERA dm Osua em 








PHP 基 础 语法 实例 返回 


说 明 

nl2br0 函 数 可 将 字符 串 中 的 找 行 符 转 成 HThL 的 换行 符号 
<?php 

$str =“ 今 天 的 天 气 特别 好 ， 心 情 也 不 错 

， 决定 去 学 校 足球 场 ， 好 好 的 踢 一 场 球 。". 

echo $str; 

echo “<br /»"; 

echo nl2br($str); 

TA 





输出 结果 

今天 的 天 气 特 别 好 ， 心 情 也 不 错 ， 决 定 去 学 校 足 球场 ， 好 好 的 踢 一 场 球 。 
今天 的 天 气 特别 好 ， 心 情 也 不 错 

， 决 定 去 学 校 足 球场 ， 好 好 的 踢 一 场 球 。 





2-11 格式 化 输出 字符 的 结 琳 


// 将 $num 里 的 数值 以 字符 串 的 形式 输出 
printf(" 数 值 为 :9%s",$num); 

echo "<br /> "; 

/转换 成 为 带 有 2 位 小 数 的 浮 点 数 
printf(" 数 值 为 :%.2f",$num); 

echo "<br />"; 

// 解 释 为 整数 并 作为 二 进 制 数 输出 
printf(" 数 值 为 :%b",$num); 

echo "<br /> "; 

HF RAFT 

printf" Z4 [H N : 7% %s",$num); 

2» 


输出 的 结果 如 图 2-712 所 示 。 


2 打印 格式 化 输出 - Nicrosoft Internet Explorer ER) 
文件 人 F) BO) SEV KEA IAM WBO IA 
OFE- O- NAOR 44x 6 O-S € 

HEHE M) E] http: //12T. 0. 0. 1/php/FHP/PHP. printf.php 二 输入 关键 词 搜索 ”加 | ERa HE Qst E | 


printf (数值 为 :%. 2£", $num) ; 
echo “<br /5"; 





/ BRE 275 SE e 3 E 26 — Xt tg b 
printf ("39 1B 25 :b", $num) ; 
echo “<br /?"; 


#7 打印 % 符 号 
printf ("数值 为 : 88s", $num) ; 


?» 


输出 结果 
数值 为 :12.8 
数值 为 :12.80 
数值 为 :1100 
数值 为 :%12.8 
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字母 大 小 写 转换 


字母 的 大 小 写 转换 在 PHP 网 页 转换 中 经 香 使 用 到 ， 涉 及 到 的 函数 命令 有 以 下 几 个 第 用 
的 ， 如 strtoupperO 可 以 将 宇 符 串 转 换 成 大 与 字母 ， 将 每 个 单词 的 第 一 个 字母 变 大 写 可 以 使 用 
ucwords0， 将 字符 串 的 第 一 个 字母 转 成 大 写 可 以 使 用 ucfirst0)， 将 字符 串 转 换 成 小 写字 母 可 
以 使 用 strtolowerO。 举 例如 下 。 


<?php 

$str = "I like this game!"; 

/将 字符 串 转 换 成 大 写字 母 

echo strtoupper(Sstr)." «br />"; 
MAFI RRRS "BE 

echo strtolower($str)."<br />"; 

/将 字符 串 的 第 一 个 学 母 转 成 大 与 
echo ucfirst($str)." «br />"; 

/将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords(Sstr); 

2» 


输出 的 结果 如 图 2-13 所 示 。 


EB 改变 宁 母 的 大 小 写 = Nicroso ft Internet Explorer 
TF AEE SAV KEA IA 帮助 H) 


QAER- O-|[9 |a (5 P €k jux 6 e- S BGL 


地 址 0) |] http: //127. 0. 0. 1/php/PHP/php. strUL. php < 输入 关键 词 搜索 M 


说 明 

















<?php 

$str = "I like this game!"; 

z/ 将 宇 符 串 转换 成 大 写字 母 

echo strtoupper($str)."4br /?"; 


zz 将 字符 串 转 换 成 小 写字 和 母 
echo strtolower($str)."4br />". 


zy 将 字符 串 的 第 一 个 字母 转 成 太 写 
echo ucfirst($str)."4br /?"; 


/1 将 每 个 单词 的 第 一 个 字母 变 大 写 
echo ucwords($str): 
D 


输出 结果 
| LIKE THIS GAME! 
i like this game! 
| like this game! 
| Like This Game! 





2-13. ”了 字母 转换 大 小 写 结 





泥人 处 理 特殊 的 字符 


有 些 字 和 人 符 对 于 MySQL 是 有 特殊 意义 的 ， 比 如 引号 、 肥 和 斜 杜 和 NULL 字符 。 那 么 如 何 正 
确 处 理 这 些 字 符 呢 ?可 以 使 用 addslashesO 函 数 和 stripslashesQrEZit, PHP 5 中 默认 是 开局 魔 















PHP 编 程 基础 


术 引 号 的 magic_quotes_gpc- 


<?php 

$str = " \"'\ NULL"; 

echo $str."<br />"; 

echo addslashes($str)."<br />"; 
echo stripslashes($str)." <br />"; 
D» 


输出 的 结果 如 图 2-14 Bron 


A 处 理 特 珠 字符 - icrosoft Internet Explorer 加 回国 
XED ”编辑 中) 查看 WW) KEAN IAM $8B500 Ld 


QmB-O-[9gmt6 搜索 JSwux 6 e- aBa 
地 址 0) E] http: //127. 0. 0. 1/php/PHP/PHP. adslashes. php -输入 关键 词 搜索 “加 | 国 和 畦 到 链接 Q snt Em 


说 明 

有 些 字 符 对 于 MySQL 是 有 特殊 意 浴 的， 比如 引号 、 吧 斜 杠 和 NULL 字 符 ， 如 何 正确 处 理 这 些 字符 ? 
我 们 可 以 使 用 addslashesj 函 数 和 stripslashes0j 函 数 ， PHP5 中 默认 是 开启 麻 术 引号 的 magic quotes gpce 
<?php 

$str =“ V" A NULL"; 

echo $str."4br />". 

echo addslashes($str)."4br /5"; 

echo stripslashes($str)."4br /?"; 

pr 











输出 结果 
"ANULL 
VY NULL 
"NULL 





(M Internet 


2-14 ”处 理 特殊 的 字符 


dx t SP eg BU [e FH 


在 HTML 中 ， 表 单 拥有 一 个 特殊 功能 : 它们 文 持 交互 作用 。 除 了 表单 乙 外 ， 儿 乎 所 有 
的 HTML 元 素 部 与 设计 以 及 展示 有 关 ， 只 要 愿意 束 可 将 内 容 传 送 给 用 户 。 为 一 方面 ， 表 单 
为 用 户 提供 了 将 信息 传送 回 Web 站 后 创建 者 和 管理 者 的 可 能 性 。 如 果 没 有 表单 ，Web DE 
一 个 静态 的 网 页 图 片 。 对 于 PHP 的 动态 网 页 开发 ， 经 营 过 到 使 用 表单 变量 对 象 ， 通 党 有 
POSTO 和 GETO 两 种 方法 ， 这 和 其 他 动态 语言 开发 的 命令 是 一 样 的 。 本 小 节 束 介绍 表单 变量 
的 使 用 方法 。 




















POST B TĘ 





作为 用 于 设置 处 理 表单 数据 的 类 型 ，POST 是 系统 的 默认 值 ， 表 示 将 数据 表单 的 数据 提 
交 到 “动作 ”属性 设置 的 文件 中 进行 处 理 。 假 设 有 一 个 HTML 表单 用 method="post" [77 3X 
传递 给 本 页 一 个 name='"test" 的 文字 信息 ， 可 用 三 种 风格 的 表单 变量 来 显示 这 个 表单 变量 ， 如 
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图 2-15 所 示 。 


<?php 

Echo $test; /简短 格式 , 需 配 置 php.ini 中 的 默认 设置 
echo $ POST["test"]; /中 等 格式 ， 推 荐 使 用 这 种 方式 
echo $HTTP POST VARS['test"]; // 见 长 格式 

7» 





LEGE WE 了 icrosoft Internet Explorer 
AEG) ”编辑 严 ) 查看 人 ”收藏 0) IAT) #6) 


QmB- O-iiztfs sx* wx O A a BL 
地 址 0) Æ] http://127.0.0. 1/php/PHP/PHP formVarpost.php v EJ 55 ue O SnagIt ET 


但 











<form method-"post" action-""» 

<input type-"text" size-"20" name-"test" /> 
<input type-"submit" value=" fA 3b" /> 
</form> 

<?php 

if(isset($ POST[ test’ ])) 

echo $ POST[' test’ ]: 

Ts 











多 Internet 


图 2-15 POST 表单 测试 





GET 和 POST 的 主要 区 别 是 : 

(1) 数据 传递 的 方式 以 及 大 小 。 

(2) GET 会 将 传递 的 数据 显示 在 url 地 址 上 ，POST 则 不 会 。 
(3) GET 传递 数据 有 限制 ， 一 般 大 量 数据 都 得 使 用 POST 方法 。 


"PEE GET 表 单 变量 


GET 表示 追加 表单 的 值 到 URL 并 且 发 送 服务 器 请 求 ， 对 于 数据 量 比较 大 的 长 表单 最 好 
不 要 用 这 种 数据 处 理 方式 。 

假设 有 一 个 HIML 表单 用 method="get" 的 方式 传递 给 本 页 一 个 name="test" 的 文字 信 
Al. H 3 种 风格 的 表单 变量 来 显示 这 个 表单 变量 。 


























<?php 

Echo $test; /简短 格式 ,需要 配置 php.ini 中 的 默认 设置 
echo $ GET['test"]; /中 等 格式 ， 推 荐 使 用 此 方法 
echo $HTTP GET VARS['test"]; /兄长 格式 

T» 


如 图 2-16 所 示 的 结果 ， 在 TE 地址 栏 里 显示 了 表单 变量 传递 的 值 。 




















X258 QUII, | 


C 表单 变量 — Microsoft Internet Explorer 
THO 编辑 人 下】 查看 WM REA IAT) *Bh»00 


OAE- O- mia mk rR 6 O-h E C 


<form method="get" action-""»5 

<input type="text” size="20" name-"test" > 
<input type="submit” value-"1E327 35b Eg" /> 
</form> 

<?php 

if (isset ($_GET[ test’ ])) 

echo $ GET[' test]; 

?> 





| 


123456 





(AD Internet 


2-16 GET 表单 测试 


LOS 子 付 串 的 连接 


TE PHP 程序 里 想 让 多 个 字符 种 进行 连接 ， 束 要 用 到 一 个 ()“ 上 点 ”号 ， 来 看 如 下 的 例子 。 


<?php 
$website = "baidu"; 





echo $website.".com"; 
T» 


EAR h RE baidu.com 
有 一 种 情况 ， 当 echo 后 面 使 用 的 是 〈") 双 引 号 ， 可 以 同样 达到 如 上 的 效 末 。 
<?php 


$website = "baidu"; 


echo "$website.com";// 双 引号 里 的 变量 还 是 可 以 正常 显示 出 来 ， 并 和 一 般 的 字符 串 自 动 区 分 开 来 











T> 
fH ar REB. MERKEA REE NFT E E DAR RDU A o 
<?php 


$website = "baidu.com"; 
echo '$website.com'; 
?> 


将 显示 $website.com。 


Section 
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量 ， 程 序 才能 对 各 种 值 进行 访问 和 和 运算。 学 习 种 量 和 变量 是 编程 的 基础 。 第 量 和 变量 的 功能 
就 是 用 来 仓储 数据 的 ， 但 区 别 在 于 钊 量 一 旦 初始 化 就 不 再 发 生变 化 ， 可 以 理解 为 符号 化 的 名 


2.5.1 PHP 中 的 常量 | 


常量 是 指 在 程序 执行 过 程 中 无 法 修改 的 值 。 在 程序 中 处理 不 需要 修改 的 值 时 ， 常 量 非常 
有 用 ， 例 如 ， 定 义 圆 周 京 PI。 第 量 一旦 定义 ， 在 程序 的 任何 地 方 都 不 可 以 修改 ， 但 是 可 以 在 
程序 的 任何 地 方 访问 。 

在 PHP 中 使 用 defineO;R AE Xx. RAE 1 个 参数 表示 音量 名 ， 第 2 个 参数 表示 第 
量 的 值 。 

例如 ， 下 面 定义 一 个 名 为 HOST 的 常量 ， 如 图 2-17 所 示 。 
































<?php 

define("HOST","www.baidu.com"); // 将 值 “www.baidu.com” 赋 于 常量 HOST 
echo HOST; /输出 HOST 常量 的 值 

Ts 


B ^34 — Nicrosoft Internet Explorer 同上 回国 
" 


AEG) SB) 查看 WW) UmROO IA 和 帮助 0) 
Q RB - O i] 2) 45 全 搜索 gx 6 A a BL 
地 址 0) |] http: //127. 0. 0. 1/php/PHP/PH?, varCN. php v Essi sm Qs 加 











代码 


<?php 

define ("HOST", “www. baidu. com^) ; CRTE “ww. baidu. com" WE-T X EHOST 
echo HOST; //jíib HOSTS, x 18 

?> 


输出 结果 


waw. baidu.com 


gx 





图 2-17 定义 常量 


种 量 说 明 如 下 。 

向 量 默认 区 分 大 小 写 ， 按 照 惯例 ， 第 量 标识 符 总 是 大 写 。 弟 量 名 和 其 他 任何 PHP 标记 
遵循 相同 的 命名 规则 。 合 法 的 常量 名 以 字母 或 下 夯 线 开始 ， 后 面 跟 任何 字母 、 数 字 或 下 面 
线 。 

PHP 的 系统 常量 包括 5 个 魔术 和 常量 和 大 量 的 预定 义 沿 量 。 

魔术 常量 会 根据 使 用 的 位 置 而 改变 ，PHP 提供 的 5 个 魔术 常量 分 别 是 : 

C) LINE : 表示 文件 中 的 当前 行 号 。 

(2) HLE : 表示 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 文件 
名 。 自 PHP 402 起 ，_FILE 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包含 一 个 相 
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对 路 径 。 
(3) FUNCTION : 表示 函数 名 称 (PHP 4.3.0 新 加 )。 自 PHP 5 起 本 常量 返回 该 函数 
被 定义 时 的 名 字 《〈 区 分 大 小 写 )。 在 PHP4 中 该 值 总 是 小 写字 母 的 。 
(4) CLASS: 表示 类 的 名 称 (PHP 4.3.0 SUED. H PHP5 起 本 常量 返回 该 类 被 定义 e) 
时 的 名 字 (区 分 大 小 写 )。 在 PHP4 中 该 值 总 是 小 写字 母 的 。 | 
(5) METHOD : 表示 类 的 方法 名 (PHP 5.0.0 新 加 )。 返 回 该 方法 被 定义 时 的 名 字 
《区分 大 小 写 为 
预定 义 常 量 又 分 为 内 核 预 定义 常量 和 标准 预定 义 常 量 两 种 ， 内 核 预 定义 常量 在 PHP 的 
内 核 、Zend 引擎 和 SAPI 模块 中 定义 ， 而 标准 预定 义 常 量 是 PHP 默认 定义 的 ， 比 如 常用 
的 E_ERROR、FE_NOTICE、E_ALL 等 。 


_PHP 中 的 变量 


在 PHP 中 ， 创 建 一 个 变量 首先 需要 定义 变量 的 名 称 。 变 量 名 区 分 大 小 写 ， 总 是 以 $ 符 号 
开头 ， 然 后 是 变量 名 。 如 果 在 声明 变量 时 ， 访 记 变 量 前 面 的 $ 符 号， 那么 该 变量 将 无 效 。 在 
PHP 中 设置 变量 的 正确 方法 如 下 所 示 。 






























































$var name = value; 


在 PHP 中 ， 可 以 使 用 值 赋值 和 引用 赋值 这 两 种 方法 为 变量 赋值 。 
值 赋值 是 下 接 把 一 个 数值 通过 赋值 表达 式 传递 给 变量 。 值 赋值 是 一 种 党 量 的 变量 冉 值 的 
方法 ， 其 使 用 格式 如 下 所 示 。 























<?php 

$name = "baidu"; IF IURE c 

$Name = "website"; IF IURE c 

echo "$name, $Name"; // 输 出 为 “baidu, website " 
$1website 2 "www.baidu.com"; /无 效 变 量 ， 以 数字 开始 
$_1website = "www.baidu.com'"; /有 效 变量 

2» 





从 上 述 代 码 中 可 以 看 到 ， 在 PHP 中 不 需要 在 设置 变量 之 前 声明 该 变量 的 类 型 ， 而 是 根 
所 变量 被 设置 的 方式 ，PHP 会 日 动 把 变量 转换 为 正确 的 数据 类 型 。 

Æ PHP 中 ， 变 量 的 命名 规则 有 如 下 儿 点 。 

(1) 变量 名 必须 以 字母 或 下 面 线 "_" 开 头 。 

(2) 变量 名 只 能 包含 字母 、 数 字 、 字 符 以 及 下 画 线 。 

(3) 变量 名 不 能 包含 空格 。 如 果 变 量 名 由 多 个 单词 组 成 ， 那 么 应 该 使 用 下 画 线 进行 分 隔 
(例如 $my_string)， 或 者 以 大 写字 母 开 头 〈 例 如 $myString )。 

Æ PHP 中 ， 还 文 持 另 一 种 赋值 方式 ， 称 为 变量 的 引用 赋值 ， 例 如 下 面 的 示例 。 

















<?php 
$wo = 'baidu'; /为 变量 $wo 赋值 
$ba = &$wo; // 取 变量 $ba 引用 了 变量 $wo 的 值 
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$ba = "Web site is $ba"; /修改 变量 $ba 的 值 
echo $wo; // 结 果 为 “Web site is baidu” 
echo $ba; /变量 $ba 的 值 也 被 修改 ， 结 果 与 $ba 相同 


?> 


x S np EUER. op de tL CREE SFAI AREER. MEE, 
变量 的 引用 赋值 导致 两 个 变量 指向 同一 个 内 存 地 址 。 因 此 ， 不 论 对 哪 一 个 变量 进行 修改 ， 修 
改 的 是 同一 个 内 存 地 址 中 的 数据 ， 从 而 出 现 同时 被 修改 的 结 

PHP 提供 了 大 量 的 预定 义 变量 ， 这 些 变 量 在 任何 范围 内 目 动 生效 ， 因 此 通 钊 也 被 称 为 目 
动 全 局 变量 (autoglobals) 或 者 超 全 局 变量 Csuperglobals) (PHP 中 没有 用 户 目 定义 超 全 局 变 
量 的 机 制 )。 在 PHP 4.1.0 之 前 ， 如 使 用 超 全 局 变量 ， 要 么 依赖 register_globals, 9i LAE 
长 的 预定 义 PHP 数组 〈$HTTP * _ VARS)。 目 PHP 5.0.0 起 ， 长 格式 的 PHP 预定 义 变量 可 
以 通过 设置 register long. arrays X B£ Mto 

种 用 的 超 全 局 变量 如 下 。 

(1) $GLOBALS: 表示 包含 一 个 引用 指 辐 每 个 当前 脚本 的 全 局 范围 内 有 效 的 变量 ， 该 数 
组 的 键 名 为 全 局 变量 的 名 称 。 从 PHP 3 开始 存在 $GLOBALS 数组 。 

(2) $ SERVER: 表示 变量 由 Web 服务 堪 设 定 或 者 直接 与 当前 脚本 的 执行 环境 相关 联 ， 
类 似 于 旧 数 组 $HTTP_SERVER_VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 

(3) $ GET: 表示 经 由 URL 请 求 提交 全 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_GET_VARS 
数组 (依然 有 效 ， 但 反对 使 用 )。 

(4) $_POST: 表示 经 由 HTTP POST 方法 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 $HTTP _ 
POST VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 

(5) $ COOKIE: 表示 经 由 HTTP COOKIE 方法 提交 至 脚本 的 变量 ， 类 似 于 旧 数 组 
$HTTP_COOKIE_VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 

(6) $_FILES: 表示 经 由 HTTP POST 文件 上 传 而 提交 全 脚本 的 变量 。 类 似 于 旧 数 组 
$HTTP_POST_FILES 数组 (依然 有 效 ， 但 反对 使 用 )。 

CI) $ ENV: 表示 执行 环境 提交 全 脚本 的 变量 ， 类 似 于 旧 数 组 SHTTP_ENV_VARS 数组 
(依然 有 效 ， 但 反对 使 用 )。 

(8) $ REQUEST: 表示 经 由 GET. POST 和 COOKIE 机 制 提 交 人 至 脚本 的 变量 ， 因 此 该 
数组 并 不 值得 信任 。 所 有 包含 在 该 数组 中 的 变量 的 存在 与 否 以 及 变量 的 顺序 均 按 照 php.ini 
中 的 variables order 配置 指示 来 定义 。 此 数组 在 PHP 4.1.0 之 前 没有 直接 对 应 的 版 本 。 

(9) $ SESSION: 表示 当前 注册 给 脚本 会 话 的 变量 ， 类 似 于 旧 数 组 $HTTP_ SESSION - 
VARS 数组 (依然 有 效 ， 但 反对 使 用 )。 


| PHP 数据 类 型 




















































































































数据 是 程序 运行 的 基础 ， 所 有 的 程序 都 是 在 处 理 各 种 数据 。 例 如 ， 财 务 统计 系统 所 要 处 
理 的 员工 工资 额 、 论 坛 程序 所 要 处 理 的 用 户 名 、 密 码 、 用 户 发 帖 数 等 等 ， 所 有 这 些 虱 是 数 
据 。 在 编程 语言 中 ， 为 了 方便 对 数据 的 处 理 以 及 市 省 有 限 的 内 容 资 源 ， 需 要 对 数据 进行 分 
Ro PHP 文 持 7 种 原始 类 型 ， 分 别 有 如 下 儿 种 。 
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(1) boolean 〈 布 尔 型 True/False). 
(2) integer (整数 类 型 )。 
(3) float 〈 浮 点 型 ， 也 称 为 double， 可 用 来 表示 实数 )。 | 
(4) string CFI RRA). c 
(5) array《〈 数 组 同一 变量 保存 同类 型 的 多 条 数据 )。 
(6) object OR 23). 
CI) 特殊 类 型 (resource 资源 和 NULL ZR EE AE. 
下 面 介绍 第 用 的 数据 次 型 。 
1. 布尔 型 boolean 
布尔 型 是 最 简单 的 类 型 ， 它 表达 了 真 值 ， 可 以 为 True 或 False。 要 指定 一 个 布尔 值 ， 使 
用 关键 学 True 或 False, J£ H. True 或 False 不 区 分 大 小 写 。 例 如 : 
$pay = True; // 给 变量 $pay 赋值 为 True 
某 些 运算 通 钟 返回 布尔 值 ， 并 将 其 传递 给 控制 流程 。 比 如 用 比较 运算 符 〈==) 来 比较 两 
个 运算 数 ， 如 果 相 等 ， 则 返回 True, URIE] False， 代 人 码 如 下 : 


if ($A — $B) { 
echo "$A 与 $B 相等 "; 
} 


对 于 如 下 的 代码 : 




















if ($pay == True) { 
echo "已 付 "; 
j 


aJ EH PIETRA: 
if ($pay) { 


echo" Bf} "; 
} 


转换 成 布尔 型 用 bool 或 者 boolean 来 强制 转换 。 但 是 很 多 情况 下 不 需要 用 强制 转换 ， 
为 当 运 算 符 、 函 数 或 者 流程 控制 需要 一 个 布尔 参数 时 ， 访 值 会 被 目 动 转换 。 

当 转 换 为 布尔 型 时 ， 以 下 值 被 认为 是 False。 

(1) 布尔 值 False。 

(20 整 型 值 0 CE. 

(3) PEU 0.0 (E). 

(4) 衬 日 字符 串 和 字符 串 "0"。 

(5) 没有 成 员 变 量 的 数组 。 

(6) 没有 单元 的 对 象 〈 仅 适用 于 PHP 4)。 

CI) 特殊 类 型 NULL (包括 尚未 设 定 的 变量 )。 

所 有 其 他 值 都 被 认为 是 True〈 包 括 任何 资源 )。 
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2. 整 型 integer 

一 个 整数 是 集合 Z={…, -2, -1 0, 1, 2,…} 中 的 一 个 数 。 整 型 值 可 以 用 十 进 制 、 十 六 进 
制 或 八进制 表示 ， 前 面 可 以 加 上 可 选 的 符号 (- 或 者 +)。 如 果 用 八进制 ， 数 学 前 必须 加 上 0 
CHE 用 十 六 进 制 ， 数 字 前 必须 加 上 0x。 整 型 数 的 字 长 和 平台 有 关 ， 通 第 最 大 值 是 大 约 二 十 
4L (32 位 有 符号 )。PHP 不 文 持 无 符 亏 整数 。 如 果 给 定 的 一 个 数 超 出 了 整 型 的 范围 ， 将 会 被 
解释 为 浮 点 型 ， 同 样 如 果 执 行 的 运算 结果 超出 了 整 型 范围 ， 也 会 返回 浮 点 型 。 

要 将 一 个 值 转换 为 整 型 ， 用 int 或 integer 强制 转换 即 可 。 不 过 大 多 数 情况 下 都 不 需要 强 
制 转换 ， 因 为 当 运 算 符 、 函 数 或 流程 控制 需要 一 个 整 型 参数 时 ， 访 值 会 日 动 转换 。 还 可 以 通 
过 函数 intval0 来 将 一 个 值 转换 成 整 型 。 

从 布尔 型 转换 成 整 型 ，False 将 产生 出 0，True 将 产生 出 1。 当 从 浮 点 数 转 换 成 整数 时 ， 
数字 将 被 取 整 《丢弃 小 数位 )。 如 果 浮 点 数 超出 了 整数 范围 ， 则 结果 不 确定 ， 因 为 没有 足够 
的 精度 使 浮 点 数 给 出 一 个 确切 的 整数 结果 。 

3. 浮 点 型 float 

浮 点 数 也 叫 双 精 度数 或 实数 ， 可 以 用 以 下 任何 语法 定义 : 

<?php 
$a = 1.234; 
$b = 1.2e3; 
$c = 7E-10; 
7» 


VEIESGBRITXHKGUESHMBA. XI AHie18e308. HHA 14 位 十 进 制 数字 的 精度 。 

4. 字符 串 string 

字符 串 是 由 引号 括 起 来 的 一 些 字 符 ， 凋 用 来 表示 文件 名 、 显 示 消 息 、 输 入 提示 符 等 。 字 
符 串 是 一 系列 字符 ， 字 人 符 串 的 大 小 没有 限制 。 字 符 串 可 以 用 单 引 号 、 双 引号 或 定 界 符 3 种 方 
法 定义 。 下 面 分 别 介绍 这 3 种 方法 。 

(1) 单 引 号 。 指 定 一 个 简单 字符 串 的 最 简单 的 方法 是 用 单 引 号 〈") 括 起 来 。 例 如 : 





QL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 




































































<?php 
echo 'Hello World '; / 输出 为 : Hello World 
2» 








如 果 字 符 串 中 有 单 引 号 ， 要 表示 这 样 一 个 单 引 号 ， 和 很 多 其 他 语言 一 样 ， 需 要 用 反 和 斜 线 
A) 转 义 。 例 如 : 
<?php 


echo 'IV m Tom'; // 输出 为 : Pm Tom 
T5 


ll RE SS | ZW BR NER Emm P SURE CO, da EH SCRI QUO. XX 
未 。 例 如 : 














<?php 
echo 'Path is c:\windows\system\\'; // 输出 为 : Path is c:\windows\system\ 
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?> 


对 于 单 引 写 CO MEFE, PHP 只 懂得 单 引号 和 反 斜 线 的 转 义 序列 。 如 末 试 图 转 义 














任何 其 他 字符 ， 反 和 鲜 线 本 映 也 会 被 显示 出 来 。 为 外 ， 人 还 有 不 同 于 双 引 号 和 定 界 符 的 很 重要 的 
一 扣 束 是 ， 单 引 写 子 符 串 中 出 现 的 变量 不 会 被 解析 。 © 
(2) 双 引 写 。 如 果 用 双 引 写 《") 括 起 子 符 串 ，PHP EREEREER XY C 








X 2-1)。 
表 2-1 转 义 字符 
序 “ 列 含 X 

n 美元 符号 

Ww XU 

" 此 正则 表达 式 序列 匹配 一 个 用 八进制 表 
示 的 字符 

此 正则 表达 式 序列 匹配 一 个 用 十 六 进 制 
表示 的 字符 











如 末 试 图 转 义 任何 其 他 字符 ， 反 和 斜 线 本 喘 也 会 被 显示 出 来 。 双 引号 字符 串 最 草 要 的 一 点 
是 能 够 解析 其 中 的 变量 。 
(30 定 界 符 。 另 一 种 给 字符 溃 定 界 的 方法 是 使 用 定 界 符 语 法 〈<<<)。 应 该 在 <<< 之 后 提 
供 一 个 标 误 从， 接 看 古 子 符 串 ， 然 后 是 同样 的 标识 答 结 束 子 符 串 。 例 如 : 
<?php 
/ 输出 为 : Hello World 
echo <<<abc 
Hello World 
abc; 
2» 
在 此 段 代码 中 ， 标 识 符 命名 为 abc。 结 束 标识 得 必 须 从 行 的 第 一 列 开始 。 标 识 符 所 如 循 
的 命名 规则 是 上 只 能 包含 字母 数字 下 画 线 ， 而 且 必 须 以 下 画 线 或 非 数 学 字符 开始 。 
定 界 符 文 本 表现 的 承 和 双 引 号 字符 串 一 样 ， 只 是 没有 双 引 号 。 这 意味 痢 在 定 界 符 文 本 中 
不 需要 转 义 引号 ， 不 过 仍然 可 以 用 以 上 列 出 的 转 义 代码 ， 变 量 也 会 家 解析。 在 以 上 的 3 种 定 
义 字 符 串 的 方法 中 ， 奋 使 用 双 引 号 或 者 定 界 符 定 义 衬 符 串 ， 其 中 的 变量 会 被 解析 。 
5. 数组 array 
PHP 中 的 数组 实际 上 是 一 个 有 序 图 ， 图 是 一 种 把 value 映射 到 key 的 类 型 。 痢 建 一 个 数 
组 使 用 array0O 语 言 结构 ， 它 接受 一 定数 量 用 过 号 分 隔 的 key => value 参数 对 。 
语法 如 下 : 






























































array( [ key => ] value , … ) 


Hp, WE key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 ， 如 果 值 又 是 一 个 数 
组 ， 则 可 以 形成 多 维 数组 的 数据 结构 。 例 如 : 








<?php 
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$edName = array(0 => "id", 1=>"username", 2-2» "password"); 
echo " 列 名 是 $edName[0]，$edName[1]，$edName[2]": 
2» 


此 段 代 人 码 的 输出 为 : F4 XE id. username. password. 
如 果 省 略 了 键 key， 会 目 动 产生 从 0 开始 的 整数 索引 。 上 面 的 代码 可 以 改写 为 : 
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<?php 

$edName = array("id", "username", "password"); 

echo " 列 名 是 $edName[0]，$edName[1]，$edName[2]": 
T» 


此 段 代 人 码 的 输出 仍 为 : FUA IE id. username. password. 
如 末 key 是 整数 ， 则 下 一 个 产生 的 key 将 是 目前 最 大 的 整数 索引 加 1。 如 来 指定 的 键 已 
经 有 了 值 ， 则 新 值 会 履 盖 旧 值 。 再 次 改写 上 面 的 代码 为 : 








<?php 
$edName = array(1=>"id", "username", "password"); 
echo " 列 名 是 $edName[1]，$edName[2]，$edName[3]": 
jo. 


此 段 代 人 码 的 输出 仍 为 : FUA IE id. username. password. 

定义 数组 的 另 一 种 方法 是 使 用 方 括号 的 语法 ， 通 过 在 方 括号 内 指定 键 为 数组 赋值 来 实 
现 。 也 可 以 省 略 键 ， 在 这 种 情况 下 给 变量 名 加 上 一 对 至 的 方 括号 〈[])。 

语法 如 下 : 








$arrayName[key] = value; 
$arrayName [] = value; 


其 中 ， 键 key 可 以 是 整 型 或 者 字符 串 ， 值 value 可 以 是 任何 类 型 。 例 如 : 





<?php 

$edName[0]= "id"; 

$edName[1]2 "username"; 

$edName[2]- "password"; 

echo "Z4 Xé$edName[0], $edName[1]. $edName[2]"; 
7> 


此 段 代 人 码 的 输出 仍 为 : PAE id. username, password. 

如 条 给 出 方 括号 但 没有 指定 键 ， 则 取 当 前 最 大 整数 索引 值 ， 新 的 键 将 是 该 值 加 1。 如 末 
当前 还 没有 整数 索引 ， 则 键 将 为 0。 如 采 指 定 的 键 已 丝 有 值 了 ， 访 值 将 被 畴 兰 。 

对 于 任何 的 类 型 一 一 布尔 、 整 型 、 浮 点 、 了 字符 串 和 资源 ， 如 果 将 一 个 值 转换 为 数组 ， 将 
得 到 一 个 仅 有 一 个 元 素 的 数组 (其 下 标 为 0)， 该 元 素 即 为 此 标量 的 值 。 如 果 将 一 个 对 象 转 
换 成 一 个 数组 ， 所 得 到 的 数组 的 元 素 为 该 对 象 的 属性 (成 员 变 量 )， 其 键 为 成 员 变 量 名 。 如 
果 将 一 个 NULL 值 转换 成 数组 ， 将 得 到 一 个 空 数组 。 
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6. 对 象 object 

使 用 class 定义 一 个 类 ， 然 后 使 用 new 类 名 构造 函数 参数 ) 来 初始 化 类 的 对 象 。 该 数 
据 类 型 将 在 后 面 的 实例 中 具体 应 用 进行 解析 。 

7. 其 他 数据 类 型 

除了 以 上 介绍 的 6 种 数据 类 型 ， 还 有 资源 和 NULL 两 种 特殊 类 型 ， 下 面 简单 介绍 一 下 资 
源 和 NULL 两 种 特殊 类 型 。 

(1) 资源 。 资 源 是 通过 专门 函数 来 建立 和 使 用 的 一 个 特殊 变量 ， 保 存 了 外 部 资源 的 一 个 
引用 。 可 以 保存 打开 文件 、 数 据 库 连接 、 图 形 画 布 区 域 等 的 特殊 句柄 ， 无 法 将 其 他 类 型 的 值 
转换 为 资源 。 资 源 大 部 分 可 以 被 系统 自动 回收 。 

(2) NULL. NULL 类 型 只 有 一 个 值 ， 束 是 区 分 大 小 写 的 关键 学 NULL。 特 殊 的 NULL 
值 表示 一 个 变量 没有 值 。 

在 下 列 情况 下 ， 一 个 变量 被 认为 是 NULL。 

(1) 被 赋值 为 NULL。 

(2) 尚未 被 赋值 。 

(3) 被 unsetO。 

例如 : 


<?php 
$php = 
if(isset($a)) 

echo *[1] is NULL<br>” ; 
$php = 0; 

if(isset($a)) 

echo “[2] is NULL«br* " ; 
$php = NUII; 

if(isset($a)) 

echo ^[3] is NULL«br* " ; 
$php = FALSE; 
if(isset($a)) 

echo *[4] is NULL«br^ " ; 
2» 


结果 是 什么 ? 

在 3 种 情况 下 ， 变 量 被 认为 是 空 值 。 

(1) 变量 没有 被 赋值 。 

(2) 变量 被 赋值 为 NULL，0，False 或 者 空 字符 串 。 
(30 变量 在 非 至 值 的 情况 下 ， 被 unset 函数 释放 。 


数据 类 型 转换 


在 PHP 中 寿 要 进行 数据 类 型 的 转换 ， 残 要 在 转换 的 变量 之 前 加 上 用 括 写 括 起 来 的 目标 类 
型 。 在 变量 定义 中 不 需要 显 式 的 类 型 定义 ， 变 量 类 型 是 根据 使 用 该 变量 的 上 下 文 所 决定 的 。 














Y . 





















































© 












PHP-* 





QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 








例如 ， 通 过 类 型 的 转换 ， 可 将 变量 或 其 所 附带 的 值 转换 成 为 外 一 种 类 型 ， 如 图 2-18 




















Wr. 
<?php 
$num = 123; // 当 前 是 整数 类 型 
$float = (float)$num; /$num 临时 性 ”地 转换 成 了 浮 点 型 ，$float 变量 所 携带 的 数据 类 型 就 为 浮 点 
型 
echo gettype($num)." «br />";// 使 用 gettype(mixed var) 函 数 来 获取 变量 类 型 
echo gettype($float) 
2» 
E ] PHP 变 量 类 型 转换 一 Nicroso ft Internet Explorer 
文件 他) 编辑 于 ) EQ) 收藏) IAM) RH aw 
QAE- O- harr wx O6 ee- LBL 
地 址 部 ) Æ] http: //127.0.0. l/php/PHP/PHP var type change. php pra iiis © SnagIt E 
<?php 
$num = 123; 
$float = (float) $num; 
echo gettype ($num). "<br />" :// H gettype (mixed var) 团 数 来 获取 变量 类 型 
echo gettype($float) 
?> 
输出 结果 
integer 
double 
aze 
图 2-18 ”数据 类 型 的 转换 
提示 : 


如 要 将 一 变量 彻底 转换 成 另 一 种 类 型 ， 就 要 使 用 settype(mixed var, string type) Až. 
允许 的 强制 转换 有 如 下 几 种 。 

(I) int, integer: 转换 成 整 型 。 

(2) bool. boolean: 转换 成 布尔 型 。 

(3) float、double、real: 转换 成 浮 点 型 。 

(4) string: 转换 成 字符 串 。 

(5) array: 转换 成 数组 。 

(6) object: 转换 成 对 象 。 


XL 
ir 





_Section 


PHP 中 的 运算 符 





对 于 学 过 其 他 语言 的 读者 ， 运 算 符 应 该 不 会 阳 生 了 。 运 算 符 可 以 用 来 处 理 数 字 、 字 符 吓 
及 其 他 比较 运算 和 所 辑 运 算 等 。 在 PHP 中， 运算 符 两 侧 的 操作 数 会 目 动 地 进行 类 型 转换 ， 
这 在 其 他 的 编程 语言 中 并 不 多 见 。 在 PHP 的 编程 中 主要 有 以 下 3 种 类 型 的 运算 符 。 

(D 一 元 运算 符 。 只 运算 一 个 值 ， 例 如 : !〈 取 反 运 算 符 ) 或 ++ (加 一 运算 符 )。 
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(2) 二 元 运算 待 。PHP 文 持 的 大 多 数 运算 符 都 是 这 种 ， 例 如 : $a + $b。 

(30 三 元 运算 待 。 即 ?， 它 被 用 来 根据 一 个 表达 却 在 妃 两 个 表达 陈 中 选择 一 个 ， 而 不 是 
用 来 在 两 个 语句 或 者 程序 路 线 中 选择 。 

PHP 中 向 用 运算 符 有 算术 运算 待 、 赋 值 运算 符 、 比 较 运 算 待 、 三 元 运算 符 、 错 误 控 制 运 
算 全 、 迪 辑 运算 人行 、 子 符 串 运算 全、 数组 运算 从 等 。 本 节 就 主要 介绍 第 用 的 运算 符 ， 以 及 运 
算 符 的 优先 级 。 

















算术 运算 符 











算术 运算 符 是 用 来 处 理 四 则 运算 的 符号 ， 是 最 简单 、 也 最 各 用 的 符号 ， 尤 其 是 数字 的 处 
理 ， 几 乎 都 会 使 用 到 算术 运算 符号 。PHP 的 算术 运算 符 如 表 2-2 Bp. 











42-2 算术 运算 符 


$a 的 负 值 


en 


z -a 

+ $a + $b $a 和 $b 的 和 

- $a — $b $a 和 $b HZ 

s $a * $b $a 和 $b 的 积 

/ $a / $b $a 除 以 $b 的 商 
% $a 96 $b $a 除 以 Sb 的 余数 
++ $a ++ $a 的 累加 

x $a—— $a 的 递减 





注意 ， 除 号 CO 总 是 返回 浮 点 数 ， 即 使 两 个 运算 数 是 整数 〈 或 由 字符 串 转 换 成 的 整 
数 ) 也 是 这 样 。 
赋值 运算 符 


赋值 运算 符 (Assignment Operator) 把 表达 式 右 边 的 值 赋 给 左边 变量 或 常量 。 其 本 的 
赋值 运算 符 是 =， 它 意味 看 把 右边 表达 式 的 值 贱 给 左边 的 运算 数 。PHP 中 的 赋值 运算 符 如 
X 2-3 所 示 。 











表 2-3 赋值 运算 符 


符 号 m — di 意 X 
= $a = $b 将 右边 的 值 连 到 左边 
+= $a += $b 将 右边 的 值 加 到 左边 ， 即 $a = $a + $b 
-= $a -= $b 将 右边 的 值 减 到 左边 ， 即 $a = $a 一 $b 
t= $a *= $b 将 左边 的 值 乘 以 右边 ， 即 $a = $a * $b 


$a /=$b 将 左边 的 值 除 以 右边 ， 即 $a = $a/ $b 















PHP-* 


不 例 
$a 96 $b 


$a .= $b 





在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 所 有 二 元 算术 和 字符 串 运 算 符 的 “组 合 运 算 符 ”， 
这 样 可 以 在 一 个 表达 式 中 使 用 它 的 值 并 把 表达 式 的 结 末 赋 给 它 ， 例 如 : 





<?php 

$a ="baidu"; 
$b =".com"; 
echo $a .= $b; 
je 


运行 结果 如 图 2-19 所 示 。 





Im 
Ac 


将 左边 的 值 除 对 右边 取 余 数 ， 即 $a = $a 96 $b 
将 右边 的 字 串 加 到 左边 ， 即 $a = $a. $b 
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A Ll — Nicrosoft Internet Explorer 
文件 他) 编辑 偿 ) 查看 人 ”收藏 以 ) IR) Bw) 


OAE- OQ-ixizf» Js JUS € 0- qc 





地 址 0) 四 http://12T.0.0. 1/php/PHP/PMP dvar.php 


代码 


<?php 

$a -"baidu"; 
$b =“. com"; 
echo $a .= $b; 
T 


输出 结果 


baldu.com 


ez 





D Internet 











图 2-19 赋值 运算 字符 串 结 果 





cou 比较 运算 符 





比较 操作 符 ， 顾 名 思 义 就 是 可 用 来 比较 的 操作 符号 
绞 运 算 符 ， 人 允许 对 两 个 值 进行 比较 ，PHP 的 比较 运算 符 如 表 2-4 所 示 。 











表 2-4 比较 运算 符 


不 例 

$a== $b True, 
$a===$b True, 

$a != $b True, 

$a <> $b True, 








èi 
xz 


如 果 $a 等 于 $b 


EEx) 
e 


v Ejss sm Qst im 





， 根 据 结果 来 返回 True 或 False. LU 


WR $a 等 于 $sb， 并 且 它 们 的 类 型 也 相同 


如 果 $a 不 恒 等 于 $b 
如 果 $a 不 等 于 $b 











未 4j 名 称 
$a != = $b 非 全 等 
$a < $b 小 于 
$a > $b XT 
$a <= $b 小 于 等 于 
$a >= $b 大 于 等 于 
三 元 运算 符 





三 元 运算 符 是 ?2:， 三 元 运算 符 的 功能 和 if.. 


(exprl1) ? (expr2) : (expr3) 





True, 


True, 


True, 


True, 


True, 
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I-A y 
F X. 





如 果 $a 不 等 于 $， 或 者 它们 的 类 型 不 同 PHP 4 引进 ) 

如 果 $a 严格 小 于 $b c 
如 果 $a 严格 大 于 $b 

如 果 $a 小 于 或 者 等 于 $b 

WR $a 大 于 或 者 等 于 $b 





else 语句 很 相似 ， 语 法 如 下 : 


首先 对 exprl 求 值 ， 硅 结果 为 True， 则 表达 式 (expr1) ? (expr2) : (expr3) 的 值 为 expr2， 合 


则 其 值 为 expr3。 例 如 : 


<?php 


$action = (empty($ POSTY['action'])) ? 'default' : $ POST['action']; 


2» 








首先 判断 $_POST[action] 变 量 是 否 为 宇 值 ， 大 是 ， 则 给 $action 赋值 为 default， 人 否则 将 
$_POST['action] 变 量 的 值 赋值 给 $action。 可 以 将 上 面 的 代码 改写 成 以 下 的 代码 : 





<?php 
if (empty($ POST['action'])) { 
$action = 'default'; 
) else ( 
$action = $ POST[action']; 


2» 





错误 控制 运算 符 








错误 控制 操作 符 (@) 可 在 任何 表达 式 前 使 用 ，PHP 文 持 一 个 错误 控制 运算 从 @。 当 将 其 
放置 在 一 个 PHP 表达 式 之 前 ， 访 表达 式 可 能 产生 的 任何 错误 信息 都 被 忽略 挥 。@ 运 算 从 只 对 


表达 式 有 效 。 





那么 ， 何 时 使 用 此 运算 符 昵 ? 一 个 简单 的 规则 就 是 ， 如 果 能 从 某 处 得 到 值 ， 吏 能 在 它 瑶 
面 加 上 @ 运 算 符 。 例 如 ， 可 以 把 它 放 在 变量 、 函 数 和 include0 调 用 、 常 量 等 之 前 。 不 能 把 它 
放 在 函数 或 类 的 定义 之 前 ， 也 不 能 用 于 条 件 结构 ， 例 如 ff 和 foreach 等 。 








对 于 如 下 的 代码 : 


<?php 
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"on "on 


$Conn- mysql connect ("localhost"," username" ,"pwd"); 
if ( SConn) 
echo "连接 成 功 ! "; 
else 
echo "连接 失败 ! "; 
2» 


如 果 mysql_connectO0 连 接 失 败 ， 将 显示 系统 的 错误 提示 ， 而 后 继续 执行 下 面 的 程 


序 。 如 果 不 想 显示 系统 的 错误 提示 ， 并 希望 失败 后 立即 结束 程序 ， 则 可 以 改写 上 面 的 代 
B F: 











<?php 
$Conn = @mysql_connect ("localhost","username","pwd") or die ("连接 数据 库 服 务 器 出 错 "); 
?> 


在 mysql. connectO K ZAT IE exe SPEAK BECAS ZH E vez S. AAEH die0 函 数 给 出 
目 定 义 的 错误 提示 ， 然 后 立即 退出 程序 。 这 种 用 法 在 大 型 程序 中 很 常见 。 











逻辑 运算 符 
PHP 的 逻辑 运算 从 (Logical Operators) 通常 用 来 测试 真 假 值 ， 和 常用 的 逻辑 运算 符 如 
dé 2-5 Wr. 
X 2-5 人 逻辑 运算 符 

and $a and $b 如 果 $a 与 $b 都 为 True 

or $a or $b 如 果 $a 或 $b 任 一 为 True 

XOr $a xor $b 如 果 $a 或 $b 任 一 为 True， 但 不 同时 是 
如 果 $a 不 为 True 
如 果 $a 与 $b 都 为 True 


如 果 $a 或 $b 任 一 为 True 











“与 ”和 “或 ”有 两 种 不 同形 式 运 筑 符 ， 它 们 运算 的 优先 级 不 同 ， 信 区 和 | 优先 级 高 。 


字符 串 运 鼻 符 

















字符 串 运算 从 (String Operator) 有 两 个 字符 串 运 算 符 。 第 一 个 是 连接 运算 符 CO), CR 
回 其 左右 参数 连接 后 的 字符 串 。 第 二 个 是 连接 赋值 运算 从 〈(.=)， 它 将 右边 参数 附加 到 左边 
的 参数 后 面 。 

例如 : 
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<?php 
$a = "你 好 "; 
$a = $a . "朋友!";/W/ 此 时 $a 是 "你 好 朋友 
$b=" 你 好 “"; | 
$b .= "朋友 !"; /此 时 $b 是 "你 好 朋友 ©) 
i» 

数组 运算 付 ) 





PHP 的 数组 运算 符 ， 如 表 2-6 所 示 。 


42-6 数组 运 鼻 符 





" m5 m i E X 
i $a 和 $b 的 联合 ， 返 回 包含 了 $a 和 Sb 中 所 有 元 素 的 数组 
Ži $a == $b 如 果 $a 和 $b 具有 相同 的 元 素 ， 就 返回 True 
Ts 两 者 具有 相同 元 素 且 顺序 相同 ， 返 回 True 
!= $a != $b 如 果 $a 和 $b 不 是 等 价 的 ， 就 返回 True 
m 如 果 $a 不 等 于 $b， 就 返回 True 
== $a != = $b 如 果 $a 和 $b 不 是 恒 等 的 ， 就 返回 True 





联合 运算 符 《+) 把 右边 的 数组 附加 到 左边 的 数组 后 面 ， 但 古 香 复 的 键 值 不 会 被 履 诲 。 
下 和 面 通过 一 个 实例 来 看 一 下 如 何 用 + 运算 从 联合 两 个 数组 : 


<?php 

$a = array("1"=>"No1", 
"2'2»"No2", 
"3"=>"No3", 
"4"=>"No4"); 


$b = array("3"=>"No3", 
"4"=>"No4", 
"5"=>"No5", 
"6"-»"No6"); 

$c = $a+$b; 

print. r($c); /联合 两 数组 
echo "<br /»"; 

if($a--$b) 

echo "等 价 "; 
else 

echo "不 等 价 "'; 


?> 


可 以 看 到 ， 在 联合 之 后 的 数组 结 来 如 图 2-20 TR o 












e RJ LE UE Microsoft Internet Explurer 

vo) aug) XE) SR 工具 Won 

Qm-oO0- HAG s ER € O- h 

AET) A8] hatg: 7127. 0.0. TT array en. pho — xpuwr [Eee um Quan p 


( [1] = Not [2] = Ne2 [3| => No3 [4] => Ned [5] => No5 [6] => Nob ) 


TG 





I Internat 


图 2-20 ”联合 数组 示例 





zoo 运算 符 的 优先 级 


运算 符 优 先 级 指定 了 两 个 表达 却 绑 定 得 有 多 “紧密 ”。 例 如 ， 表 达 了 式 1 + 2 * 31m: 47e 
7 而 不 是 9 EDDA Co 的 优先 级 比 加 号 O m. QE RI ELS orm lee poc 
级 ， 例 如 (1+2)*3 的 值 为 9。 使 用 括号 也 可 以 增强 代码 的 可 读 性 。 如 果 运 算 符 优先 级 相同 ， 
则 使 用 从 左 到 右 的 左 结合 顺序 左 结 合 表 示 表 达 式 从 左 问 右 求 值 ， 右 结合 相反 )。 

K 2-7 从 高 到 低 列 出 了 PHP 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具 有 相同 优先 
级 ， 此 时 它们 的 结合 方 问 决定 求 值 顺序 。 






































表 2-7 运算 符 优 先 级 


结合 方向 z 算 符 附加 信息 

dE new 

^r array() 
den pne 递增 / 递减 运算 符 
非 结 合 ! ~ - (int) (float) (string) (array) (object) @ 类 型 

"9 算数 运算 符 
E 算数 运算 符 和 字符 串 运算 符 
^r 位 运算 符 
deem 比较 运算 符 
非 结合 比较 运算 符 

A 位 运算 符 和 引用 
^r 位 运算 符 

^r 位 运算 符 

^r 逻辑 运算 符 
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e 
$ 





方 问 运 SW 附加 信息 


Er 





逻辑 运算 符 
三 元 运算 符 
=+= —= *=/= = þ= &= |= ^= <<= >>= 赋值 运算 符 
and 逻辑 运算 符 
xor 逻辑 运算 符 
or 逻辑 运算 符 
多 处 用 到 
合 前 面 所 用 到 的 操作 符号 来 完成 一 项 需要 综合 使 用 它们 的 任务 ， 如 图 2-21 rz. 
<?php 














/定义 几 个 常量 ， 最 好 是 使 用 大 写 
define(" PEN", 20); /钢笔 为 20 元 
define("RULE",10); /尺子 为 10 元 


$pen_num = 10; /10 只 钢笔 
$ruler num 220; /20 把 尺子 


$total price = $5pen num * PEN 
4 $ruler num * RULE; 


$total price = number. format(Stotal price); 


echo "购买 10 只 钢笔 和 20 把 尺子 一 共 要 人 花 ".$total_price." 元 "; 


A 操作 符 综 合 使 用 - Hicrosoft Internet Explorer 
FP 编辑 人 F) ”查看 0) BEA IAM 帮助 0) 


Qm- O- (i6 Ps zr e e- aBa 
地 址 (D) |Æ] http://127. 0. 0. 1/php/PHP/PHP_use_op. php < 输入 关键 词 搜索 €Ejss sm Q snust E 








define("RULE", 10); /7 尺子 为 10 元 


$pen num = 10; //10H $83 
$ruler num 220; /720 把 尺子 


$total price = $pen num * PEN 
+ $ruler num * RULE; 


$total price = number format ($total price); 


echo “HR 10 H $5840 2018 RF — 3E E15". $total price."J60"; 
Tà 


输出 结果 
购买 10 只 钢笔 和 20 把 尺子 一 共 到 花 400 元 





(AD Internet 


2-01 综合 运算 符 的 应 用 示例 


423 CES 
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| Section 
PHP 的 表达 式 


在 PHP 程序 中 ， 任 何 一 个 可 以 返回 值 的 语句 ， 都 可 以 看 做 表达 式 。 也 束 是 说 ， 表 达 式 
是 一 个 短语 ， 能 够 执行 一 个 动作 ， 并 具有 返回 值 。 一 个 表达 式 通 第 由 两 部 分 构成 ， 一 部 分 是 
操作 数 ， 另 一 部 分 是 运算 符 。 本 贡 介 绍 利用 的 几 种 控制 语句 表达 式 ， 分 别 是 条 件 语 铅 、 循 环 
WAJ, UK require 和 include 语句 等 其 他 语句 。 


2A 


条 件 语句 在 PHP rPdER DR, i6 PHP 程序 的 主要 控制 语句 之 一 。 通 常情 况 下 ， 在 客户 
问 获 得 一 个 参数 ， 根 据 传 入 的 参数 值 ， 做 出 不 同 的 啊 应 。 在 PHP 中 条 件 语 句 分 别 为 让 3E 
AJ, if-else 语句 、if-elseif-else 语句 和 switch 语句 。 

下 面 我 们 分 别 介绍 这 4 种 形式 的 条 件 语句 : 

1. ifi& 4] 

if EAE S mA a PEHEA A, EH 让 语句 可 以 按照 条 件 判断 来 执行 语句 ， 
增强 了 程序 的 可 控制 性 。 只 有 站 语句 的 条 件 语句 是 最 简单 的 一 种 条 件 语句 ， 语 法 如 下 : 





























if ( expr ) 


statement 


首先 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如果 值 为 False， 将 忽略 


statement. 


图 2-22 Brzs EXER E SEAT ENT TIGRE EE e 


d 
ST GU | wem E 
False ((&) 


图 2-22 让 语句 逻辑 示意 网 










例如 : 


<?php 
$Num1=10; 
$Num2=9; 
if($Num1>$Num2) 
echo "$Num1 KF $Num2"; 
2» 


上 述 实例 演示 了 f 语句 的 使 用 ， 会 在 变量 $Numl 大 于 $Num2 时 ， 输 出 “$Numl 大 于 
$Num2", 
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2. if-else 语 名 
条 件 语句 的 第 2 种 形式 是 if-else， 除 了 让 语句 之 外 ， 还 加 上 了 else 语句 ， 它 可 以 在 直 话 
人 名 中 的 表达 式 的 值 为 False 时 执行 ， 语 法 如 下 : 


if ( expr ) © 


statement1 
else 
statement2 


首先 ， 对 expr 求 值 ， 如 果 expr 的 值 为 True， 则 执行 statement; 如 果 值 为 False， 则 执 
ÍT statement2。 例 如 ， 人 以 下 代码 在 $a 大 于 $b 时 ， 显 示 a 大 于 b; 有 反之， 则 显示 a 不 大 于 bb。 
这 种 情况 的 执行 逻辑 结构 如 图 2-23 所 示 。 


True ( 真 ) 


A 









False ((B) 
图 2-23 if-else 语句 逻辑 示意 图 


例如 ， 以 下 代码 在 $a 大 于 $b 时 ， 显 示 a 大 于 b; 及 之 ， 则 显示 a 不 大 于 b。 





<?php 
if ($a > $b) 
echo "a 大 于 b"; 
else 


echo "a 不 大 于 b"; 


?> 


注意 : 

else 语句 仅 在 if MA elseif (如 果 有 的 话 ) 语句 中 的 表达 式 的 值 为 False 时 执行 ， 它 不 可 
以 单独 使 用 。 

3. if-elseif-else 语 和 铝 

条 件 语句 的 第 3 种 形式 是 if-elseif-else, elseif 是 让 和 else WHE. M else 一 样 ， 它 延伸 
了 站 语句 ， 可 以 在 原来 的 站 表达 式 值 为 False 时 执行 不 同 语句 。 但 是 和 else 不 一 样 的 是 ， 它 
仅 在 elseif 的 条 件 表达 式 值 为 True 时 执行 语句 ， 语 法 如 下 : 


if ( expl ) 
statementl 





elseif ( exp2 ) 
statement2 
elseif ( exp3 ) 


else 


statementn 
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首先 ， 对 exprl 求 值 ， 如 果 exprl 的 值 为 True， 则 执行 statement1， 如 果 值 为 False， 则 
对 expr2 求 值 , 如 果 expr2 的 值 为 True， 则 执行 statement2; 如 果 值 为 False, Jl] expr3 求 
值 ， 依 次 类 推 ， 如 果 所 有 的 表达 式 的 值 都 为 False， 则 执行 statementn。 

这 种 情况 的 执行 逻辑 结构 如 图 2-24 所 示 。 





图 2-24 if-elseif-else 语句 逻辑 示意 
例如 ， 以 下 代码 将 根据 条 件 分 别 显 示 a 大 于 b，a 等 于 b 和 a 小 于 bb: 


<?php 
if ($a > $b) { 
echo "a 大 于 b"; 
} elseif ($a == $b) { 
echo "a 等 于 b"; 
} else { 
echo "a 小 于 b"; 
} 
2» 
注意 : 
elseif 也 可 以 写成 else if (两 个 单词 )， 它 和 elseif (一 个 单词 ) 的 行为 完全 一 样 。 
4. switch 语 句 
使 用 switch 语句 可 以 避免 大 量 地 使 用 if-else 控制 语句 。switch 语句 首先 根据 变量 值得 到 
一 个 表达 式 的 值 ， 然 后 根据 表达 式 的 值 执行 语句 。switch 语句 计算 expression 的 值 ， 然 后 和 
case 后 的 值 进行 比较 ， 跳 转 到 第 一 个 匹配 的 case 语句 开始 执行 后 面 的 语句 ， 如 果 没 有 case 
匹配 就 跳 转 到 default 语句 执行 ， 如 果 没 有 default 语句 ， 则 退出 。 当 找到 匹配 项 的 时 候 ， 解 
析 器 会 一 直 运 行 ， 直 到 switch 结尾 或 者 遇见 break 语句 为 止 。case 语句 可 以 使 用 空 语句 。 
PHP 提供 了 分 文 (switch) 语句 来 下 接 处 理 多 分 文选 择 ， 语 法 如 下 : 














switch (expr) { 
case constant-expression: 
statement 
jump-statement 
[default: 
statement 














第 2 音 ISh 





jump-statement 
] 
j 


其 中 的 常量 表达 式 (constant-expression〉 可 以 是 任何 求 值 为 简单 类 型 的 表达 式 ， 即 整 型 e 
或 浮 点 数 以 及 字符 串 。 
其 逻辑 结构 如 图 2-25 所 示 。 








图 2-25 switch EAJ 4R8 Z5] 


下 面 一 段 代 码 是 switch 语句 的 简单 应 用 : 


<?php 
switch ($a) { 
case 0: 
echo "a = 0"; 
break; 
case 1: 
echo "a = 1"; 
break; 
case 2: 
echo "a = 2"; 
break; 
} 


?> 


switch 语句 一 行 接 一 行 地 执行 《实际 上 是 语句 接 语 句 )。 开 始 时 没有 代码 被 执行 ， 仅 当 
一 个 case 语句 中 的 值 和 switch 表达 式 的 值 上 匹配 时 ，PHP 才 开 始 执行 语句 ， 直 到 switch 的 程 
序 段 结束 或 者 遇 到 第 一 个 break 语句 为 止 。 如 果 不 在 case 的 语句 段 最 后 写 上 break 的 话 ， 
PHP 将 继续 执行 下 一 个 case 中 的 语句 段 。 例 如 : 





<?php 
switch ($a) { 
case 0: 
echo "a = 0"; 
case 1: 
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这 里 如 果 $a 等 于 0, PHP 将 执行 所 有 的 输出 语句 ; 如 果 $a 等 于 1, PHP 将 执行 后 面 两 
条 输出 语句 。 只 有 当 $a 等 于 2 时 ， 才 会 得 到 结果 : a = 2。 


循环 语 名 


循环 语句 也 称 为 从 代 语句 ， 让 程序 香 复 执行 某 个 程序 块 ， 直 到 某 个 特定 的 条 件 表达 式 结 
果 为 假 时 ， 结 束 执行 语句 块 。 在 PHP 中 循环 语句 的 形式 有 : while 循环 、do-while 循环 、for 
循环 和 foreach 循环 。 

1. while 循 环 语句 

while 语句 控制 语句 的 循环 执行 。 格 式 为 : 











while (expr) 
statement 


只 要 expr 的 值 为 True 就 重复 执行 嵌 套 中 的 循环 语句 。 每 次 开始 循环 时 检查 expr 的 
值 。 有 时 如 果 while 表达 式 的 值 一 开始 就 是 False， 则 循环 语句 一 次 都 不 会 执行 。 一 般 来 
说 ， 在 代码 片段 中 会 改变 表达 式 中 变量 的 值 ， 否 则 可 能 成 为 死 循环 。 图 2-26 所 示 为 该 语句 
的 迎 辑 结构 。 











图 2-26 while 语句 逻辑 示意 


例如 : 


<?php 
$a = 1; 
while ($a <= 5) { 
echo $a++; // 从 1~5 依次 输出 
} 
dS 
执行 该 程序 后 会 输出 从 1 一 5 的 数字 。 
2. do-while 循 环 语句 
do-while 语句 和 while 语句 基本 一 样 。 不 同 之 处 在 于 ，while 语句 在 “{}” 内 的 语句 执行 
之 前 检查 条 件 是 否 满足 ， 而 do-while 语句 则 先 执行 “f” 内 的 语句 ， 然 后 再 判断 条 件 是 否 满 
是， 如 末 满 足 就 继续 循环 ， 不 满足 束 跳 出 循环 。 格式 为 
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do 
statement 


while(expr) 


图 2-27 所 示 为 该 语句 的 逻辑 结构 。 





False ( 假 ) 


图 2-27 do-while 语句 逻辑 示意 图 
例如 : 


<?php 
$a = 0; 
do { 
echo $a; 


} 
while ($a > 0); 
2» 


以 上 循环 将 正好 运行 一 次 ， 因 为 经 过 第 一 次 循环 后 ， 当 检 答 表达 陈 的 真 值 时 ， 因 其 值 为 
False ($a 不 大 于 0) mj su EIE. 

3. for 循 环 语句 

for 循环 是 PHP 中 最 复杂 的 循环 结构 。for 循环 的 语法 是 : 























for (expr1; expr2; expr3) 


statement 


其 中 ， 第 1 个 expl 在 循环 开始 前 无 条 件 求 值 一 次 。 第 2 个 expr2 在 每 次 循环 开始 前 求 
值 ， 如 来 值 为 Tre， 则 继续 循环 ， 执 行 租 僚 的 循环 语句 ; 如果 值 为 False， 则 终止 循环 。 第 3 
个 expr3 在 每 次 循环 之 后 被 求 值 〈 执 行 )。 每 个 表达 式 都 可 以 为 衬 。expr2 为 空 意 味 看 将 无 限 
循环 下 去 (和 C 一 样 ，PHP 认为 其 值 为 True)， 因 为 有 时 候 会 希望 用 break 语句 来 结束 循 
环 ， 而 不 是 用 for 的 表达 式 真 值 判断 。 

图 2-28 所 示 为 该 语句 的 逻辑 结构 ， 表 达 式 2 为 True 则 执行 程序 片段 ， 其 值 在 表达 式 1 
中 初始 化 ， 在 表达 式 3 中 进行 修改 。 
































False (fB) 
图 2-28 for 语句 逻辑 示意 网 
下 面 通过 使 用 for 循环 语句 输出 九 九 乘法 表 : 


<?php 
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for($i=1;$i<10;$i++) 
{ 
for($j=1;$j<10;$j++) 
{ 
echo "$i*+$j=".$i*$j; 
echo "&nbsp"; 
j 


echo "<br/>"; 


j 
2» 
4. foreach 循 环 语句 
foreach 语句 是 一 种 用 来 过 历数 组 中 数据 的 简便 方法 。foreach 仪 能 用 于 数组 ， 当 试图 将 
其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 时 会 产生 错误 。foreach 语句 有 两 种 语法 ， 第 2 
种 比较 次 要 ， 但 却 是 第 1 种 的 有 用 的 扩展 。 
第 1 种 语法 : 
foreach (array_expression as $value) 


statement 
第 2 种 语法 : 


foreach (array_expression as $key => $value) 


statement 


第 1 种 语法 格式 过 历 给 定 的 array expression 数组 。 每 次 循环 中 ， 当 前 单元 的 值 被 赋 给 
$value， 并 且 数 组 内 部 的 指针 问 前 移 一 步 〈 因 此 下 一 次 循环 中 将 会 得 到 下 一 个 单元 )。 第 2 种 
格式 做 同样 的 事 ， 只 除了 当前 蛙 元 的 键 名 也 会 在 每 次 循环 中 被 赋 给 变量 $key. HAIT BJ 
辑 结构 如 图 2-29 所 示 。 








False ( 假 ) 








图 2-29 foreach 语句 逻辑 示意 图 








该 语句 的 使 用 方法 如 下 : 


<?php 
$arr = array("one", "two", "three"); 
foreach ($arr as $value) { 
echo "Value: $value<br />\n"; 


j 


?> 


WEBERA AN : 
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Value: one 


Value: two 
Value: three 


在 这 段 代 码 中 遍历 数组 使 用 的 是 foreach 语句 的 第 1 种 格式 ， 也 可 以 使 用 第 2 种 格式 。 O) 
改写 上 面 的 代码 如 下 : 


<?php 
$arr = array("one", "two", "three"); 





foreach ($arr as $key => $value) { 
echo "Key: $key; Value: $value<br />\n"; 
}2> 


此 段 代码 的 输出 为 : 


Key: 0; Value: one 
Key: 1; Value: two 
Key: 2; Value: three 


其 他 语句 
为 了 帮助 程序 员 更 加 精确 地 控制 整个 流程 ， 方 便 程序 的 设计 ，PHP 还 提供 了 一 些 其 他 语 
人 句 ， 这 里 做 一 下 简单 的 介绍 。 

(1) break 语句 。break 语句 用 来 结束 当前 的 for. while 或 switch 循环 结构 ， 继 续 执 行 下 
面 的 语句 。break 语句 后 面 可 以 跟 一 个 数学 ， 用 于 在 散人 套 的 控制 结构 中 表示 跳出 控制 结构 的 

(2) continue 语句 。continue 语句 用 来 跳出 循环 体 ， 不 继续 执行 循环 体 下 耐 的 语句 ， 而 
是 回 到 循环 判断 表达 式 ， 并 决定 是 否 继续 执行 循环 体 。continue 语句 后 面 同样 可 以 跟 一 个 数 
字 ， 其 作用 和 break 语句 相同 。 

(3) return 语句 。return0) 语 句 通常 用 于 函数 中 ， 如 果 在 一 个 函数 中 调用 retumO i88), X4 
立即 结束 此 水 数 的 执行 并 将 它 的 参数 作为 函数 的 值 返 回 。 

(4) includeO 语 名 和 requireO 语 句 。 包 含 并 运行 指定 文件 。require0 和 includeO 除 了 处 理 
失败 之 外 ， 在 其 他 方面 都 完全 一 样 。include0 产 生 一 个 警告 ， 而 require0 则 导致 一 个 致命 错 
误 。 也 就 是 说 ， 如 果 想 在 丢失 文件 时 停止 处 理 页 面 ， 应 该 使 用 require0， 而 includeO0 则 会 继 
续 执 行 脚本 ， 同 时 也 要 确认 设置 了 合适 的 include path. 

(5) require once()i Jl include_once) f]. require once i5 5]4l include_onceO 语 句 分 
别 对 应 requireO 语 句 和 includeO 语 句 。require_once0 语 句 和 include onceQ18 4] EAH T vi 
包含 多 个 文件 时 ， 可 以 有 效 地 避免 把 同一 段 代 但 包含 进去 而 出 现 函 数 或 变量 重复 定义 的 错 


IRo 
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PHP 的 函数 


程序 在 完成 一 个 功能 时 ， 可 以 把 众多 的 程序 写 在 一 起 ， 但 这 样 容 易 引 起 混乱 。 为 一 种 策 
略 加 是 把 总 的 功能 分 成 小 的 功能 异世 ， 把 每 一 个 模块 分 别 实 现 ， 在 总 的 框 杂 中 根据 需要 把 模 
块 搭建 在 一 起 。 实 现 程 序 模块 化 的 全 略 束 是 使 用 函数 ， 和 直观 来 说 ， 函 数 束 是 代表 一 组 语句 的 
标识 从， 在 使 用 函数 时 ， 外 部 调用 者 不 需要 关心 函数 的 内 部 处 理 过 程 ， 只 需要 关心 函数 的 输 
入 和 输出 接口 的 应 用 。 函 数 可 以 人 刹 单 地 分 为 两 大 类 : 一 类 是 系统 函数 ， 一 类 是 用 户 目 定义 隙 
数 。 对 于 系统 函数 ， 可 以 在 需要 时 下 接 选 择 使 用 ， 而 用 户 目 定义 函数 ， 痛 先 要 定义 ， 然 后 才 
能 使 用 。 本 节 的 重点 是 如 何 定义 并 使 用 用 户 目 定义 函数 ， 主 要 包括 函数 定义 的 一 般 形 式 、 函 
数 的 参数 和 返回 值 、 函 数 的 租 套 和 地 归 等 。 


ETUE 使 用 函数 


一 个 函数 可 由 以 下 的 语法 来 定义 : 









































function funcName([$arg_1][, $arg_2][，…][, $arg npf 
statement 


j 


定义 函数 是 需要 使 用 function KEF, LL Jn xe ERU. BAI RAA AL LRE A 
线 打 头 ， 后 面 跟 字母 、 数 字 或 下 画 线 。$arg_1 füSarg n 为 函数 的 可 选 参数 列表 ， 不 同 的 参数 
之 间 用 喜 号 分 隔 。 在 函数 内 部 可 以 放置 任何 有 效 的 PHP 代 人 但， 甚 全 包括 其 他 函数 和 凑 定 
义 。 

例如 : 


<?php 

function maxNum($a,$b){ 
$c-$a»$b?$a:$b; 

return $c; 

} 

echo maxNum(10,100); // 输出 : 100 


上 和 面 的 一 段 代 人 码 也 可 以 写成 : 


<?php 

echo maxNum(10,100); // 输出 : 100 
function maxNum($a,$b){ 
$c-$a»$b?$a:$b; 

return $c; 


j 


?> 
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设置 函数 参数 | 


通过 函数 参数 列表 可 以 传递 信息 到 函数 。PHP 支持 按 值 传递 参数 ， 通 过 引用 传递 以 及 默 
认 参 数 。 默 认 情况 下 ， 冰 数 参数 通过 值 传递 ， 即 若 在 函数 内 部 改变 了 参数 的 值 ， 也 不 会 影响 
到 函数 外 部 的 值 。 

例如 : 


<?php 

function change($string){ 
$string = "改变 之 后 "; 

} 

$str = "ELA"; 

change($str); 





echo $str; 
Is 


这 段 代码 的 输出 为 “改变 之 前 ”。 尽 管 在 国 数 内 部 改变 了 参数 $string KIE, iA 
到 函数 外 部 $str 的 值 。 如 采 布 望 允许 函数 修改 它 的 参数 值 ， 必 须 通 过 引用 传递 参数 ， 方 法 是 
在 函数 定义 中 该 参数 的 前 面 预 先 加 上 “ 信 ” 符 号 。 

修改 上 面 的 代码 如 下 : 





<?php 

function change(&$string){ 
$string = "& AÈ Z Jn"; 

} 

$str= 改变 之 六 

change(Sstr); 

echo $str; 

jo: 


这 段 代 人 码 的 输出 为 “改变 之 后 ”。 在 函数 内 部 改变 了 参数 $string 的 值 ， 也 影响 到 了 函数 
外 部 $str 的 值 。 前 后 两 段 代 但 的 唯一 区 列 融 是 ， 后 面 一 段 代 但 的 参数 传递 是 引用 传递 ， 即 在 
因数 定义 中 的 参数 前 面 加 上 了 “人 ”符号 。 


ECKE y [n] E ALB | 


所 有 的 函数 都 可 以 有 返回 值 ， 也 可 以 没有 返回 值 ， 主 要 是 通过 使 用 可 选 的 return 18.4] 
返回 值 。 任 何 类 型 都 可 以 返回 ， 其 中 包括 列表 和 对 象 。 这 导致 图 数 立即 结束 运行 ， 并 且 将 控 
制 权 传递 回 被 调用 的 行 。 

举例 如 下 : 


<?php 
$num1=100; 











er 


f PHP+ 





$num2-2200; 
echo "最 大 的 是 ".maxNum($num1, $num2); / 输出 : 最 大 的 是 200 
function maxNum($a,$b){ 
if($a<$b) $a = $b; 
return $a; 


j 


?> 





E A B Fa 


PHP IM Zi n UREE XAH. PIIBHCROE Xo WÜUETEXEOL 7 BRAAUNE, H 














HARARE. AAN RI ERU BE CE Q5 E HE ERU URL 8. E 


效 ， niis 


<?php 
function foo() 
{ 
function bar() 
{ 
echo "并 没有 关闭 直到 foo0 函 数 被 应 用 ."; 
j 
j 
F* ANBEBCEIVHR] baroke DAE JPRCH ABO BI. 对 
foo(); 
ILAE nT EAE HR] baror ži, 
fooO's 的 进程 允许 使 用 . */ 
bar(); 
2» 


这 段 代 码 的 输出 为 “并 没有 关 财 、 直 到 foo0 函 数 被 应 用 。”。 








所 请 垦 套 调用 ， 束 是 在 调用 一 个 函数 的 过 程 中 ， 又 调用 为 一 个 函数 。 举 例如 下 : 


<?php 

$num1=100; 

$num2=200; 

myoutput($num1, $num2); 

function myoutput($a, $b){ 

echo "最 大 的 是 ".maxNum($a, $b); 
} 

function maxNum($a,$b)( 

if($a<$b) $a = $b; 

return $a; 


j 


?> 


这 段 代 人 码 的 输出 是 “最 大 的 是 200”. fEJG BLEUS F AHA myoutput0， 而 在 调用 这 
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个 函数 的 过 程 中 ， 又 调用 了 另 一 个 函数 maxNumO,. AE RA RC UR] H] 
PHP 中 还 允许 函数 的 递归 调用 ， 即 在 调用 一 个 函数 的 过 程 中 又 直接 或 则 接地 调用 该 函数 
本 喘 。 举 例如 下 : 


<?php © 


recursion(5); 
function recursion($a) 
{ 
if ($a <= 10) { 
echo "$a "; 
recursion($a + 1); 
} 
} 


?> 
这 段 代 码 的 输出 是 数字 5，6，7，8，9，10。 在 此 段 代 码 中 首先 调用 的 recursion, m 
在 调用 这 个 函数 的 过 程 中 ， 如 果 参 数 的 值 小 于 等 于 10， 则 又 调用 此 函数 本 有 身 ， 这 残 是 函数 的 
递归 调用 。 秽 套 和 递归 的 应 用 在 使 用 PHP 进行 一 些 结算 系统 的 应 用 时 经 常 使 用 到 ， 需 要 读 
者 举一反三 ， 清 晰 地 掌握 逻辑 关系 后 才 可 以 进行 应 用 ， 否 则 经 和 常 容易 出 现 死 循环 。 
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PHP 和 MySQL 数 据 库 的 操作 





要 想 快 速成 为 PHP 网 页 编程 蜗 手 ， 核 心 掌 握 PHP 和 MySQL 的 数据 库 操作 是 非常 重要 
的 。 一 般 PHP 实现 对 MySQL. 的 操作 主要 包括 连接 、 创 建 、 搬 入、 选择、 查询、 排序、 更 狐 
以 及 删除 等 操作 。 下 和 面 就 分 别 介 绍 一 下 实现 这 些 功 能 的 函数 命令 。 


| 连接 数据 库 mysq|l_connect() 


在 能 够 访问 并 处 理 数 据 库 中 的 数据 之 前 ， 必 须 创 建 到 达 数 据 库 的 连接 。 在 PHP P, X 
个 任务 通过 mysql_connect) K Zi o8 p. 

语法 : mysql connect(servername,username, password) 

举例 如 下 。 

在 下 面 的 例子 中 ， 在 一 个 变量 中 ($conn) 存放 了 在 脚本 中 供 稍 后 使 用 的 连接 。 如 果 连 接 


失败 ， 将 执行 die 部 分 。 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 : . mysql. error); 

} 


TS 
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脚本 一 结束 ， 了 驶 会 关闭 连接 。 如 需 提 前 关 团 连接 ， 使 用 mysql_close() 函数 实现 。 


<?php 


$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : '. mysql_error); 
} 
mysql_close($conn); 
1> 


o P 





创建 数据 库 CREATE 


CREATE DATABASE 语句 用 于 在 MySQL 中 创建 数据 库 。 

语法 : CREATE DATABASE database name 

为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql_query) PR. RAAHE MySQL 
XE pec ys tM ptg e 

举例 如 下 。 

在 下 面 的 例子 中 ， 创 建 了 一 个 名 为 my. db 的 数据 库 : 





<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : '. mysql. errorQ); 
} 
if (mysql query "CREATE DATABASE my_db",$conn)) 
{ 
echo "Database created"; 
} 
else 
{ 
echo "Error creating database: " . mysql. error(); 
} 
mysql close($conn); 
2» 


CREATE TABLE 用 于 在 MySQL 中 创建 数据 库 表 。 
语法 : 


CREATE TABLE table name 
( 

column namel data type, 
column name2 data type, 
column name3 data type, 
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为 了 执行 此 命令 ， 必 须 问 mysql_query) PAIS] CREATE TABLE 语句 。 


举例 如 下 。 c 
下 例 展示 了 如 何 创建 一 个 名 为 Persons 的 表 。 此 表 有 3 列 ， 列 名 是 FirstName, 
LastName 以 及 Age: 


<?php 
$conn = mysql_connect("localhost 
if (!I$conn) 
{ 
die(' 不 能 连接 数据 库 :' mysql_error0); 
j 
if (mysql. query "CREATE DATABASE my. db",$conn)) 
{ 


echo "Database created"; 


} 
else 
{ 
echo "Error creating database: " . mysql_error(); 
} 
mysql select db("my. db", $conn); 
$sql = "CREATE TABLE Persons 
( 
FirstName varchar(15), 
LastName varchar(15), 
Age int 
) "n : 
mysql. query($sql,$conn); 
mysql close($conn); 
2» 


在 创建 表 之 前 ， 首 先 必须 选择 数据 库 。 通 过 mysql select dbO. AZOA ŽE EE. CA BUSE 
varchar 类 型 的 数据 库 字 段 时 ， 必 须 规 定 该 字段 的 最 大 长 度 ， 例 如 varchar(15)。MySQL 各 种 
数据 类 型 表 如 表 2-8 一 表 2-11 所 示 。 


"o "on 


, root"," admin"); 





表 2-8 MySQL 数据 类 型 表 





数值 类 型 Hx 
int(size) 
smallint(size) 仅 支持 整数 
eie) | 在 size 参数 中 规定 数字 的 最 大 值 
bigint(size) 


decimal(size,d) | — 支持 带 有 小 数 的 数字 


pure 在 size 参数 中 规定 数字 的 最 大 值 。 在 d 参数 中 规定 小 数 点 右 侧 的 数字 的 最 大 值 
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表 2-9 文本 数据 类 型 表 


文本 数据 类 型 jü 述 
文 持 固 定 长 度 的 字符 串 。【〈 可 包含 字母 、 数 字 以 及 特殊 符号 ) 






































har(si E e 
ue 在 size 参数 中 规定 固定 长 度 
etes 支持 可 变 长 度 的 字符 串 〈( 可 包含 字母 、 数 字 以 及 特殊 符号 ) 
在 size 参数 中 规定 最 大 长 度 
tinytext 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 255 个 字符 
TM 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 65535 个 字符 
mediumtext EE Poe 
süedhusmblob SCEEHTAEHEBEBUAE REB. EAK 16777215 个 字符 
l Z. È Iu AA 三 | pa Du y 
eee 支持 可 变 长 度 的 字符 串 ， 最 大 长 度 是 4294967295 个 字符 
表 2-10 日 期 数据 类 型 表 
日 期 数据 类 型 jJ ” R 
date(yyyy-mm-dd) 
datetime(yyyy-mm-dd hh:mm:ss) 支持 日 期 或 时 间 


timestamp(yyyymmddhhmmss) 
time(hh:mm:ss) 


R 2-11 杂项 数据 类 型 表 





杂项 数据 类 型 ji 述 
enum(valuel ,value2,ect) enum 是 enumerated 列表 的 缩写 。 可 以 在 括号 中 存放 最 多 65535 ME 
set set 与 enum 相似 。 但 是 ，set 可 拥有 最 多 64 个 列表 项 目 ， 并 可 存放 不 止 一 个 choice 





每 个 表 都 应 有 一 个 主键 字段 。 主 键 用 于 对 表 中 的 行进 行 唯 一 标识 ， 每 个 主键 值 在 表 中 必 
须 是 唯一 的 。 此 外 ， 主 键 字段 不 能 为 空 ， 这 是 由 于 数据 库 引 擎 需要 一 个 值 来 对 记录 进行 定 
位 。 主 键 和 字段 永 远 要 被 编 入 索引 ， 这 条 规则 没有 例外 ， 必 须 对 主键 字段 进行 索引 ， 这 样 数 据 
库 引 擎 才能 快速 定位 给 予 该 键 值 的 行 。 

下 面 的 例子 把 personID 字段 设置 为 主键 字段 。 主 键 字 段 通 单 是 ID 写 ， 且 通常 使 用 
AUTO INCREMENT 设置 。AUTO_INCREMENT 会 在 新 纪录 被 添加 时 逐一 增加 该 字段 的 
值 。 要 确保 主键 字段 不 为 宇 ， 必 须 同 该 字段 添加 NOT NULL XH. 
举例 如 下 。 


$sql = "CREATE TABLE Persons 

( 

personID int NOT NULL AUTO INCREMENT, 
PRIMARY KEY (personID), 

FirstName varchar(15), 

LastName varchar(15), 

Age int 

)5 

mysql query($sql,$Sconn); 
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插入 数据 INSERT INTO 


INSERT INTO 语句 用 于 同 数 据 库 表 洪 加 新 记录 。 © 
语法 : 





INSERT INTO table name 
VALUES (valuel, value2,::-) 


还 可 以 规定 希望 在 其 中 插入 数据 的 列 : 


INSERT INTO table name (columnl, column2,::: 
VALUES (valuel, value2,::-) 











SQL 语句 对 大 小 写 不 敏感 。 INSERT INTO 与 insert into 相同 。 为 了 让 PHP 执行 该 语 
AJ, WEH mysql_query) 函数 。 该 函数 用 于 癌 MySQL. 连接 发 送 得 询 或 命令 。 

举例 如 下 。 

在 前 面 创建 了 一 个 名 为 Persons 的 表 ， 有 3 列 : Firstname, Lastname 以 及 Age. HEF 
例 中 使 用 同样 的 表 。 下 面 的 例子 癌 Persons KDT 2 个 新 记录 : 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die( 不 能 连接 数据 库 :". mysql. errorO); 
} 
mysql select db("my. db", $conn); 
mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES (chen', 'yicai', 35"); 
mysql query("INSERT INTO Persons (FirstName, LastName, Age) 
VALUES (yu, 'heyun', '28)"); 
mysql. close($conn); 














?> 
选取 数据 SELECT 
SELECT 语句 用 于 从 数据 库 中 选取 数据 。 
语法 : 


SELECT column name(s) FROM table name 


SQL 语句 对 大 小 写 不 pos IX, SELECT 与 select 等 效 。 为 了 让 PHP 执行 上 面 的 语句 ， 必 须 
使 用 mysql queryO. 函数 。 函数 用 于 内 MySQL AX AWS « 

举例 如 下 。 

下 面 的 例子 选取 存储 在 Persons 表 中 的 所 有 数据 CS. 字符 选取 表 中 所 有 数据 ): 














上 和 面 这 个 例子 在 $result 变量 中 存放 由 mysql queryO 


vA 





HP+IV 
<?php 

$conn = mysql_connect("localhost","root","admin"); 

if (!$conn) 


{ 
die(' 不 能 连接 数据 库 :'. mysql_error()); 
} 
mysql select db("my. db", $conn); 
$result = mysql query( SELECT * FROM Persons"); 
while($row = mysql. fetch, array(S$result)) 
{ 
echo Srow[ FirstName'] . " " . Srow['LastName']; 
echo "<br /»"; 
} 
mysql close($conn); 
2» 
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函数 返回 的 数据 。 接 下 来 ， 使 用 


mysql_fetch_arrayO 国 数 以 数组 的 形式 从 记录 集 返 回 第 1 行 。 随 后 对 mysql_fetch_array() P 
数 的 每 次 调用 都 会 返回 记录 集中 的 下 一 行 。while loop 语句 会 循环 记录 集中 的 所 有 记录 。 为 
了 输出 每 行 的 值 ， 使 用 了 PHP 的 $row 变量 ($row['FirstName'] 和 $row['LastName'])。 











条 件 查询 WHERE 





如 需 


选取 匹配 指定 条 件 的 数据 ， 请 向 SELECT 语句 添加 WHERE 子 句 。 
语法 : 


SELECT column FROM table 
WHERE column operator value 





下 和 面 如 表 2-12 所 示 的 运算 符 可 与 WHERE 子 句 一 起 使 用 。 


SQL 





R 2-12 可 用 于 碍 询 的 运算 符 


运 算 mW 说 明 
= 等 于 
I= 不 等 于 
> NF 
< 小 于 
>= 大 于 或 等 于 
<= 小 于 或 等 于 
BETWEEN 介 于 一 个 包含 范围 内 
LIKE 搜索 匹配 的 模式 








语句 对 大 小 与 不 a WHERE 与 where 等 效 。 为 了 让 PHP 执行 上 面 的 语句 ， 必 
须 使 用 mysql. queryOrRZi.. iAPRUH T IRI. SQL 连接 发 这 会 询 和 命令 。 
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举例 如 下 。 
下 面 的 例子 将 从 Persons 表 中 选取 所 有 FirstName-'Root' 的 行 : 


<?php | 
$conn = mysql connect("localhost", "root", "admin"); c 
if (!$conn) | 

{ 

die(' 不 能 连接 数据 库 : '. mysql_error); 

} 
mysql select db("my. db", $conn); 
$result = mysql query( SELECT * FROM Persons 
WHERE FirstName- chen"); 


while($row = mysql. fetch, array($result)) 
{ 
echo $row[ FirstName'] . 
echo "<br >"; 


j 


2» 


"on 


. $row['LastName']; 


数据 排序 ORDER BY ) 


ORDER BY 关键 词 用 于 对 记录 集中 的 数据 进行 排序 。 
语法 : 





SELECT column name(s) 
FROM table name 
ORDER BY column name 





SQL 对 大 小 写 不 敏感 ，ORDER BY 5 order by 等 效 。 
举例 如 下 。 
下 面 的 例子 选取 persons 表 中 存储 的 所 有 数据 ， 并 根据 Age 列 对 结果 进行 排序 


<?php 
$conn = mysql_connect("localhost 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 :'. mysql_error()); 

} 
mysql select db("my. db", $conn); 
$result = mysql. query( SELECT * FROM Persons ORDER BY Age"); 
while($row = mysql. fetch, array($result)) 

{ 


echo Srow[ FirstName']; 


"o "on 


, root"," admin"); 


"on 


echo " " . $row['LastName']; 
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echo " " . $row['Age']; 
echo "<br />": 


j 
mysql close($conn); 
jo. 


如 果 使 用 ORDER BY 关键 词 ， 记 录 集 的 排序 顺序 默认 是 升序 (1 在 9 之 前 a 在 p 之 
前 )。 使 用 DESC 关键 词 来 设 定 降序 排序 (9 在 1 之 前 , p 在 a 之 前 ): 














SELECT column name(s) 
FROM table name 
ORDER BY column name DESC 


可 以 根据 两 列 进行 排序 ， 也 可 以 根据 多 个 列 进行 排序 。 当 按照 多 个 列 进行 排序 时 ， 只 有 
第 1 列 相同 时 才 使 用 第 2 列 : 


SELECT column name(s) 
FROM table name 
ORDER BY column namel, column name2 


更 新 数据 UPDATE 


UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 。 
语法 : 
UPDATE table name 


SET column name = new. value 


WHERE column name = some value 


SQL 对 大 小 与 不 敏感 ，UPDATE 与 update 等 效 。 为 了 让 PHP HÁT EMEA, qeu 
用 mysql_gquery0 函 数 。 该 函数 用 于 癌 SQL 连接 发 送 查 询 和 命令 。 

举例 如 下 。 

下 向 的 例子 更 狐 Persons 表 的 一 些 数据 : 








<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 

{ 

die(' 不 能 连接 数据 库 :'. mysql. errorQ); 

} 
mysql select db("my. db", $conn); 
mysql query("UPDATE Persons SET Age = '38' 
WHERE FirstName = 'chen' AND LastName = 'yicai'"); 
mysql close($conn); 
1> 





_PHP 编 程 基 础 


2 删除 数据 DELETE FROM 


DELETE FROM 语句 用 于 从 数据 库 表 中 删除 记录 。 >D 
语法 : 











DELETE FROM table name 
WHERE column name = some value 





SQL 对 大 小 写 不 敏感 ，DELETE ; FROM 与 delete from 等 效 。 为 了 让 PHP 执行 上 面 的 语 
人 句 ， 必 须 使 用 mysql. query( ) 函 数 。 访 函数 用 于 同 SQL 连接 发 送 在 询 和 命令 。 
举例 如 下 。 


<?php 
$conn = mysql_connect("localhost","root","admin"); 
if (!$conn) 
{ 
die(' 不 能 连接 数据 库 : . mysql. error); 
} 
mysql_select_db("my_db", $conn); 
mysql query("DELETE FROM Persons WHERE LastName-'yicai'"); 
mysql close($conn); 
s 


本 小 市 介绍 了 PHP 实现 MySQL 数据 库 的 一 些 常 用 操作 ， 读 者 在 学 习 的 时 候 一 定 要 认真 
编写 每 一 行 的 代码 ， 养 成 民 好 的 规范 ， 方 便 今 后 的 提高 学 习 。 
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对 于 初学 者 而 言 ， 学 习 PHP 入 门 最 好 的 方法 就 是 使 用 Dreamweaver 配合 MySQL 进行 动态 系 
统 的 开 有 发。 之 所 以 说 它 是 最 好 的 方法 是 因为 可 以 用 Dreamweaver. 内 置 的 服务 器 行为 天 联 起 来 。 
Dreamweaver 提供 了 方便 的 网 形 化 界面 ， 只 需 使 用 鼠标 选择 ， 输 入 一 些 基 本 设置 参数 束 能 够 与 
MySQL 数据 库 交 互 ， 实 现 建立 数据 、 得 询 记 录 、 痢 增 记 录 、 更 新 记录 、 删 除 记 录 等 操作 ， 人 简单 地 
说 ， 不 用 目 己 写 程 序 即 可 以 实现 Dreamweaver+MYySQL 动态 系统 的 开发 。 本 章 将 介绍 如 何 使 用 这 
些 服务 右 行 为 ， 引 导 大 家 去 阅读 由 Dreamweaver 所 产生 的 程序 代码 ， 了 解 Dreamweaver 的 程序 远 
辑 ， 同 时 掌握 PHP 动态 网 页 开发 的 基础 和 一 些 重 要 的 概念 。 





sa MA ATJE) EIU 


HFA TARA: 


© 掌握 Dreamweaver 进行 PHP 开发 的 流程 
(7 搭建 PHP 动态 系统 开发 的 平台 

(— 检查 数据 库 记 录 的 常见 操作 

O 编辑 记录 的 常见 操作 
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Dreamweaver 动 太 网 页 制作 步 又 


使 用 Dreamweaver 中 的 服务 器 行为 可 以 快速 实现 PHP, ASP 以 及 JSP 等 动态 网 站 
的 功能 开发 。 对 于 初学 者 而 言 不 用 掌握 相关 的 程序 编写， 只 需要 掌握 一 定 的 操作 顺 
序 ， 了 解 相 关 的 服务 器 行为 即 可 以 轻松 实现 动态 网 站 的 建设 。 设 计 使 用 Dreamweaver 
成 功 进行 PHP 动态 网 页 的 制作 并 创建 一 个 动态 Web 站 点 ， 可 以 用 如 下 几 个 关键 步骤 来 
X11 « 

第 一 步 : 设计 静态 PHP 页 面 

在 设计 任何 Web 站 点 (无 论 是 静态 的 还 是 动态 的 ) 时 的 一 个 关键 步骤 是 页 面 视 觉 效 果 
的 设计 。 当 癌 网 页 中 添 加 动态 元 妹 时 ， 页 面 的 设计 对 于 其 可 用 性 至 关 重 要 。 要 仔细 考虑 用 户 
将 如 何 与 各 个 页 面 和 整个 Web 站 点 进行 交互 。 

将 动态 内 容 合 并 到 网 页 的 常用 方法 是 创建 一 个 显示 内 容 的 表格 ， 然 后 将 动态 内 容 导 
该 表格 的 一 个 或 多 个 单元 格 中 。 利 用 此 方法 ， 可 以 用 一 种 结构 化 的 格式 来 表示 各 种 类 型 的 
Hio 

第 二 步 : 创建 动态 内 容 源 

动态 Web 站 点 需要 一 个 内 容 源 ， 在 将 数据 显示 在 网 页 上 之 前 ， 动 态 Web 站 点 需要 从 该 
内 容 源 提取 这 些 数 据 。 能 在 网 页 中 使 用 内 容 源 之 前 ， 必 须 执 行 以 下 操作 。 

(1) 创建 动态 内 容 源 (如 数据 库 ) 与 处 理 该 页 面 的 应 用 程序 服务 器 之 间 的 连接 。 使 用 
“ 绑 定 ”面板 创建 数据 源 ， 然 后 可 以 选择 数据 源 并 将 其 插入 到 页 和 面 中 。 

(2) 通过 创建 记录 集 ， 指 定 要 显示 的 数据 库 中 的 信息 ， 或 指定 希望 在 该 页 面 中 包括 的 变 
量 。 还 可 以 在 记录 集 对 话 框 内 测试 查询， 并 可 以 进行 任何 必要 的 调整 ， 然 后 再 将 其 添加 到 
“ 绑 定 ”和 面板 。 

(3) 选择 动态 内 容 元 条 并 将 其 插入 到 选 定 页 向 。 

第 三 步 : 向 网 页 添加 动态 内 容 

定义 记录 集 或 其 他 数据 源 并 将 其 添加 到 “ 绑 定 ”面板 后 ， 可 以 将 该 记录 集 所 代表 的 动态 
内 容 插入 到 页 面 中 。Dreamweaver 的 沫 单 张 动 型 界面 使 得 添加 动态 内 容 元 素 非常 和 测 单 ， 只 需 
从 “ 绑 定 ”面板 中 选择 动态 内 容 源 ， 然 后 将 其 插入 到 当前 页 面 内 的 相应 文本 、 网 像 或 表单 对 
象 中 即 可 。 

将 动态 内 容 元 素 或 其 他 服务 器 行为 插入 到 页 面 中 时 ，Dreamweaver 会 将 一 段 服务 需 冰 脚 
本 插入 到 该 页 面 的 源 代 码 中 。 访 脚本 指示 服务 堪 从 定义 的 数据 源 中 检索 数据 ， 然 后 将 数据 呈 
现在 该 网 页 中 。 奉 要 在 网 页 中 放置 动态 内 容 ， 请 执行 以 下 操作 之 一 。 

(D 将 其 放 在 “代码 ”视图 或 “设计 ”视图 中 的 插入 点 处 。 

(2) 蕉 换文 本 字符 串 或 其 他 占 位 符 。 

(3) 将 其 插入 到 HTML 属性 中 。 例 如 ， 动 态 内 容 可 以 定义 图 像 的 src 属性 或 表单 域 的 
value 属性 。 

第 四 步 : 向 页 面 添加 服务 器 行为 

除了 添加 动态 内 容 外 ， 还 可 以 通过 使 用 服务 器 行为 将 复杂 的 应 用 程序 逻辑 结合 到 网 
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供 更 强 的 交互 性 能 和 功能 。 

Dreamweaver 服务 堪 行 为 可 以 问 Web. x ESSA HIER YEAR. TAA ESI. 
B6 Dreamweaver 提供 的 服务 器 行为 支持 ColdFusion. ASP 和 PHP 文档 类 型 。 服 务 器 行为 经 
过 精心 编写 和 仔细 测试 ， 达 到 快速 、 安 全 和 可 菲 的 目的 。 内 置 服务 上 右 行 为 文 持 跨 平台 网 页 ， 
x& HT PUR D Vds e 

Dreamweaver 提供 指 癌 并 单 击 (pointrand-click) 界 面 ， 这 种 界面 使 得 将 动态 内 容 和 
复杂 行为 应 用 到 页 面 瓯 像 插 入 文本 元 素 和 设计 元 素 一 样 答 单 。 可 使 用 的 服务 器 行为 如 
下 上 所 述 。 

(OD 定义 来 目 现 有 数据 库 的 记录 集 。 所 定义 的 记录 集 随 后 存储 在 “ 绑 定 ”面板 中 。 

(2) 在 一 个 页 面 上 显示 多 条 记录 。 可 以 选择 整个 表 、 包 含 动 态 内 容 的 各 个 单元 格 或 各 
行 ， 并 指定 要 在 每 个 页 面 视图 中 显示 的 记录 数 。 

(3) 创建 动态 表 并 将 其 插入 到 页 面 中 ， 然 后 将 该 表 与 记录 集 相 关联 。 以 后 可 以 分 别 使 用 
属性 检 得 器 和 重复 区 域 服务 器 行为 来 修改 表 的 外 观 和 重复 区 域 。 

(4) 在 页 面 中 插入 动态 文本 对 象 。 插 入 的 文本 对 象 是 来 目 预定 义 记 录 集 的 项 ， 可 以 对 其 
应 用 任何 数据 格式 。 

(5) 创建 记录 导航 和 状态 控件 、 主 /详细 页 面 以 及 用 于 更 新 数据 库 中 信息 的 表单 。 

(6) 显示 来 自 数据 库 记 录 的 多 条 记录 。 

CD 创建 记录 集 导 航 链 接 ， 这 种 链接 允许 用 户 查 看 来 日 数据 库 记 录 的 前 和 面 或 后 面 的 记录 。 

(8) 添加 记录 计数 器 ， 以 帮助 用 户 跟 踩 返 回 的 记录 数 以 及 其 在 返回 结果 中 所 处 的 
位 置 。 

(9) 还 可 以 通过 编写 目 己 的 服务 堪 行 为 或 者 安 钱 由 第 三 方 编写 的 服务 器 行为 来 扩展 
Dreamweaver 服务 器 行为 。 

第 五 步 : 测试 和 调试 页 面 

在 将 动态 页 或 整个 Web 站 点 发 布 到 Web 上 之 有 前， 应 首先 测试 其 功能 。 通 过 测试 可 以 检 
得 程序 开发 的 结果 ， 如 果 出 现 错误 要 及 时 进行 更 改 。 







































































搭建 PHP 动 态 系统 平台 


ERHI PHP 动态 网 页 开发 其 实 很 简单 ， 本 章 融 以 实例 的 形式 具体 介绍 Dreamweaver 中 
服务 器 行为 的 使 用 方法 。 在 开始 制作 一 个 PHP 网 站 之 表 ， 需 要 在 Dreamweaver 中 定义 一 个 
狐 网 站 。 在 “新 建站 点 ”中 可 以 让 Dreamweaver 知道 现在 的 网 站 本 地 目录 及 测试 的 路 径 等 信 
县 ， 另 外 一 项 工作 就 是 数据 库 的 创建 工作 。 


系统 结构 设计 


“PHP 动态 功能 ”的 系统 结构 设计 如 图 3-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登 录入 口 
与 找 回 密码 入 口 两 个 部 分 ， 其 中 index.php 是 这 个 网 站 的 首页 。 
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PHP 动态 系统 







index.php 


detail.php update.php 





图 3-1 PHP 动态 系统 结构 图 


在 本 地 的 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CS 5.5 的 网 站 环境 中 可 以 按 (F12) 





键 来 浏览 网 页 ， 还 可 以 在 IE 浏览 器 输入 “http:/localhosVphpweby/index.php” 来 打开 用 户 系统 
的 首页 index.php， 其 中 phpweb 为 站 点 名 。 
在 实例 中 ， 会 使 用 到 以 下 5 个 页 面 ， 整 个 网 站 的 架构 束 如 表 3-1 所 示 。 


表 3-1 PHP 动态 功能 网 页 设计 表 





页 面 名 称 J 能 
index.php 系统 首页 用 来 显示 记录 清单 
detail.php 显示 记录 详细 信息 页 面 
add.php 添 增 记 录 页 面 
update.php 更 新 记录 页 面 
del.php AN ER EKE rt 





index.php 用 于 浏览 数据 库 内 记录 ， 为 detail.php 提供 附带 URL 参数 ID 的 超级 链接 ， 便 
于 得 看 详细 的 记录 信息 ， 如 图 3-2 所 示 。 
A PHP 动 态 系 统 - Nicrosoft Internet Explorer DER) 
ax 


WHF AmE EAM Kwa) IAM) 和 帮助 H) 
OGAE- O-[9 à (5 sS kax O 由- AGL 
地 址 D) Æ] http: //127. 0.0. 1/phpweb/ index. php < 二 输入 关键 词 搜索 M gesa 链接 Qsnagrt [Sj 


PHP 动 态 系统 














共有 10 笔 记录 ， 目 前 查看 第 1 笔 至 第 5 笔 
姓名 年 龄 
test1 
test2 
test? 
testd 
test5 


1 
2 
3 
4 
3 





4B Internet 





图 3-2 index 页 面 效果 


detail.php 用 于 接收 由 index.php 传 来 的 URL 参数 ID, AH URL. 参数 往 选 数据 库 中 的 记 
录 。 更 新 与 删除 记录 都 是 依据 数据 库 中 的 主键 字段 ID 来 识别 记录 的 ， 如 图 3-3 所 示 。 
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A 详细 页 面 = Kicroso ft Internet Explorer 

XO) RED 查看 WW) 收藏 如) IAM $8500 
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HEHE M) |] http: //12T. 0. 0. 1/phpweb/detail.php?ID-1 二 输入 关键 词 搜索 €-Ejes ue Qsscc 国 
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3-3 detail.php 页 面 效 果 


当 制 作 一 个 PHP 动态 网 站 时 ， 事 前 规划 网 站 的 架构 是 一 件 很 重要 的 事情 。 这 个 网 站 在 
设计 人 员 的 脑子 里 要 有 一 个 骏 形 ， 如 大 概 有 哪些 页 面 、 页 面 间 的 关系 如 何等 。 数 据 库 的 如 构 
规划 也 是 一 样 的 ， 如 要 有 哪 坚 数据 表 、 和 字段 ， 如 何 跟 网 页 配合 等 ， 都 是 很 重要 的 事情 。 


c 创建 用 户 数据 库 


PHP 动态 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 DD、 姓 名 、 年 龄 、 成 绩 等 4 个 字段 。 
所 以 在 数据 库 中 必须 包含 一 个 容纳 上 述 信 息 的 表 ， 将 数据 库 命 名 为 phpweb. 。 接 下 来 要 在 
MySQL 建立 网 站 数据 库 作 为 任何 数据 得 询 、 痢 增 、 修 改 与 删除 的 后 端 文 持 。 制 作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", YEA MySQL 数据 库 的 管理 面 
板 ， 如 图 3-4 所 示 。 

(2) 单 击 工具 栏 的 Create GD) 按钮 ， 并 在 打开 的 下 拉 沈 单 中 单 击 选择 “Database 
(数据 库 )” 命 令 ， 如 图 3-5 所 示 。 
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3-4 打开 MySQL 数据 库 3-5 ĦAJ% “DataBase” MeS 
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Dreamweaver+PHP 开 发 基础 





(3) 打开 “Create DataBase Wizard (建立 数据 库 同 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
^phpweb". 然后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 如 图 3-6 所 示 。 


Create Database 


Specify the name for a new database 





Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 


SQL 
mm- Manager Database name phpweb 
。 forMySQL 











Register after creating 





图 3-6 输入 数据 库 的 名 称 phpweb 


(4) 设置 MySQL 数据 库 的 属性 设置 如 表 3-2 所 示 ， 连 接 设 置 如 图 3-7 所 示 。 然 后 再 单 
iH Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 





表 3-2 数据 库 属性 设置 


Host name localhost Port 3306 
User name root 
Password admin 


Create Database Wizard 
Create Database 


Set connection properies for a new database 


Host name localhost v | Port 


User name 

















| 
Password | 











Lise server settings 














allation 





[C] Use tunneling 
Tunneling 


5H tunneling 








图 3-7 “数据库 连接 设置 
(5) 打开 新 建 数据 库 的 SQL 语句 提示 创建 数据 库 phpweb， 直 接 单 击 Next (下 一 步 ) f 


钮 ， 如 图 3-8 所 示 。 












PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


Create Database Wizard 
Create Database 
Result SOL statement. Click the Finish button to create a new database. 


Result SiL statement: 
CREATE DATABASE "phpweb': 





- for MySQL 





E TR 


Click "Finish" ta create the database. 








图 3-8 ”完成 设置 


(6) 单 击 Finisnh《〈 完 成 ) 按钮 ， 打 开 注 册 数 据 库 的 设置 男 面 ， 在 选择 utf8 FHR, fA 
中 文 版 的 GB2312 版 ， 其 他 的 保持 默认 值 ， 如 图 3-9 所 示 。 本 书 用 Dreamweaver 创建 的 php 
网 页 默认 的 字符 集 格式 是 charset=utf8， 所 以 建立 的 MySQL 格式 全 部 为 utf8。 





Database Registration Info 


$^ Connection 
I | Display Options Host name 


I Directories User name 


ant 
HTTP Tunneling Database name hpweehb 
fa 





v 
IE] Data Options 


Database alias Phpwweb an localhost 


Font charset GB2312 CHARSET (Simplified Chinese charak k 





图 3-9 ”选择 简体 中 文 版 


(7) "Pali OK 人 确认) 按钮， 就 完成 了 数据 库 phpweb 的 新 增 工作 。 

数据 库 建立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 是 websql. ££ 
立 数据 库 后 ， 接 着 再 按 左 边 的 “Connect to Database (连接 数据 库 )” 图 标 电 将 其 连接 上 ， 这 
张 数据 表 的 字段 结构 内 容 说 明 如 下 。 

(1) 建立 数据 库 phpweb 后 ， 用 鼠标 右键 单 击 选 择 “Table 〈 表 格 )” 选 项 ， 在 打开 的 来 
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单 中 单 击 选择 “New Table (新 表格 )” 命 令 ， 如 图 3-10 所 示 。 

(20 数据 库 右 方面 向 会 出 现 新 建 数据 表 (Table) 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields (内 容 )”、“DDL KI)” 3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 
websql， 如 图 3-11 所 示 。 





g Hew Table — [phpweb on localhost] 


— me ae 
Table Properties 











| E phpweb on localhost [php' {v 





Table name websgl 


co E o Storage Options 


g Compile Storage engine MyISAM] 























@) Show SQL help | Row format DEFAULT 
|! [E Restore default size || Min. rows 














<><> 


Mew Table... Ctrlthy 
a 


III Refresh Tables F5 








了 Auto increment value 








0 
7 Max. rows 0 
0 


p Average row length 














<*> < < 


= Database Registration Info... «| Size for index key blocks 0 





[C] Check sum [C] Delay key write 
[ ]Pack keys C] Temporary 


Character Sets |File Options | Merge Table Options | Federated Table Options 
Character set Default v 
Collation Default v 


3-10 ”开始 建 数据 表 3-11 输入 数据 表 名 websql 


(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 3-12 所 示 。 


New Tab from Here... 





Rename Curent T ab... 








Delete Current T ab 
Find Item... Ctrl+F 






































g Table - [websgl] - [phpweb on localhost] 
Object Al | Properties | Fields Indices | Triggers || Data | Dependencies | DDL 


Field Name Field Type — Size Preci... Not N... Default Comment 
[3 phpweb on localhost [p sv " 
3 ) i D Null 
Eg websgl v | 


General A " 























[a] Refresh 


f Compile 

Qs Grants on table 

ca Print 

9) Show SQL help 

d Table Editor options 
[EF] Restore default size 














3-12 ”设置 数据 库 字段 
各 字段 如 表 3-3 所 示 。 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 和 成 绩 。 


表 3-3 websql 数据 表 


字段 名 称 字段 型 态 说 明 
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也 可 以 直接 在 DOS 的 MySQL 输入 管理 状态 下 和 直接 创建 数据 表 ， 实 现 的 命令 如 下 : 


CREATE TABLE ‘websgl ( 
"ID? int(11) NOT NULL AUTO INCREMENT, 
"Name' varchar(20) DEFAULT NULL, 
"Age tinyint(4) DEFAULT NULL, 
"Result. varchar(20) DEFAULT NULL, 
PRIMARY KEY CID)) 

) ENGINE=MyISAM DEFAULT CHARSET=utf8; 


(4) 为 了 下 面 页 面 制作 的 调用 需要 ， 可 以 事先 在 数据 表 里 加 入 10 笔 数 据 ， 单 击 “Date 
(数据 )” 选 项 卡 ， 在 数据 表 手 动 加 入 名 为 testl~testl0 的 10 个 用 户 ， 年 龄 和 成 绩 也 编辑 不 同 
的 数据 ， 如 图 3-13 所 示 。 


Æ Table — [websgl] - [phpweb on localhost] 


Object Al | Properties | Fields | Indices | Triggers | Data | Dependencies DDL | 
d bet-a A EAHA E Me 














[3 phpweh on localhost [p v 
时 websq v 




















i WY name * age ** Result v 
= 
(g) Refresh zi bii. 
3 test3 


| 学 Compile 4 testd 
由 Ss Grants on table 5|test5 

e» Print B5 teste 
T testT 
€) Show SQL help e[testa 
dh Table Editor options S|test9 


Restore default size 10 test10 











Grid view Form View Print Data 


a Commit transaction Records fetched: 10/10 Open Time: 32 ms LIMIT 0, 1000 











图 3-13 加 入 10 笔 数 据 


3.2.3 定义 phpweb 站 点 | 


在 Dreamweaver CS 5.5 中 创建 一 个 “PHP 动态 系统 ”网 站 站 点 pppweb， 由 于 这 是 PHP 
数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 堪 ， 主 要 的 设置 如 表 3-4 Hrs. 


表 3-4 站 点 设置 的 基本 参数 


站 点 名 称 phpweb 
本 机 根 目录 CAApacheMtdocsphpweb 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhosU/phpweb/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataMySQL\MySQL Server 5.5\data\phpweb 
管理 账号 / 密码 root / admin 
数据 库 名 称 websql 


创建 phpweb 站 点 具体 操作 步骤 如 下 。 
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(1) 首先 在 C:\Apache\htdocs 路 径 下 建立 phpweb 文件 夹 ， 如 图 3-14 所 示 ， 本 章 所 有 建 
区 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 

(2) 运行 Dreamweaver CS 5.5， 选 择 荣 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 3-15 PTR. 


-\Apache\htdo 
Xo) BB) Woo Mw TAa) Mhon 

QAR- O- Ø ARR ox" [3 

IAS D) 1 C: AApocheihtdves > baia 


` azau 

XH X PEXCUESS ! | meServerScripis 2011-1-11 10:5? 

2011-1-20 15:36 
m) Ee » 
gy BETIA VM bb egens 
[) SUE TEX 文件 2011-6-45 9:41 
C UxTIMEROWUm in XM 2011-7 9/35 

Yab 


2011-6-30 15.30 
= ERER 2011-T-i1 18.49 
O BANT im 2004-11-20 15:16 


Q "W 21176 0: 
BERTIE st 
x ET 2011-1-29 10:14 


编辑 (ED... 
FAE] 
HEF E] 

导出 M)... 








3-14 ”建立 站 点 文件 夹 pppweb 3-15 “管理 站 点 ”对 话 框 


(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 上 所 有 已 经 定义 的 站 点 。 单 击 右边 的 “新 
建 ” 投 钮 ， 打 开 “ 站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

"yh: phpweb 

“本 地 站 点 文件 来” ”C:\Apache\htdocs\phpweb\ 

如 图 3-16 所 示 。 


站 点 设置 对 人 鳃 phpweb 











Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。Drearmweaver 
站 点 通常 常 包含 两 个 部 分 ， 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 和 到 web 上 的 服务 器 上 的 远程 文件 夹 。 











您 可 以 在 此 处 汶 Dreamweaver 站 点 选择 本 地 立 件 来 和 名 称 。 
zE Hi sd d reb: | C'\Apachehhtdocs\phpweb\ F3 





3-16 ££ phpweb 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 此 |， 打 开 “ 基 本 ” 


选项 卡 ， 进 行 如 图 3-17 所 示 的 参数 设置 。 
“服务 磺 名 称 ” phpweb 
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“连接 方法 本地/ 网络 
“服务 需 文 件 严 ” CNApacheMitdocs 
“Web URL”: http:// localhost/phpweb. 


站 点 设置 对 和 锡 phpweb 
服务 器 名 称 ; 
连接 方法 ;| 本 地 /网 络 | 
服务 器 文件 夹 ! [ciapachetdos ë ë ë OS 
Web URL: | http://127.0.0. 1/phpweb/ 











3-17 设置 “基本 ”选项 卡 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同步 
言 息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 


的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 3-18 所 示 。 


靖 点 设置 对 旬 phpweb 


版 本 控制 远程 服务 器 
* ”高 级 设置 M 维护 同步 信息 
O 保存 时 自动 将 净 件 上 传 到 服务 器 
O 启用 文件 取出 功能 


[V] 打开 文件 之 前 取出 


取出 名 称 : 








电子 邮件 地 址 : (00000000000 





3-18 设置 “高 级 ”选项 卡 
(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 勺 选 “ 测 试 ” 复 选 按钮 ， 
如 图 3-19 所 示 。 




















第 3 章 i Dr eamwea ver*PHPZT Zz Z& fuh 


WAKAS phpweb 


Li 您 将 在 此 位 置 选择 承载 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 


服务 器 LED : 1 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


* ”高 级 设置 





注意 ; 要 开始 在 Dreamweaver 站 点 上 了 工作， 您 无 需 完成 此 步 又 。 如 果 要 和 连接 到 web 并 发 
布 页 面 ， 您 只 需 定 义 一 个 远程 服务 器 即 可 。 





| 地 址 | 连接 | 远程 | T 


C:lApachejhtdocs/ 本 地 | 网 络 (V 


图 3-19 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 ORE REOR. 在 Dreamweaver CS 5.5 rk Gg T Wi 
才 所 设置 的 站 点 phpweb。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 杠 ， 这 样 就 完成 了 
Dreamweaver CS 5.5 测试 PHP 动态 系统 网 页 的 网 站 环境 设置 。 


CA 设置 数据 库 连 接 

完成 了 站 点 的 定义 后 ， 接 下 来 就 是 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 连接 
设置 如 下 。 

(1) 执行 肖 单 栏 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 index.php 的 
网 页 ， 输 入 网 页 标题 “PHP 动态 系统 ”， 然后 执行 过 单 “文件 ”一 “保存 ”命令 将 网 页 保 
存 ， 如 图 3-20 所 示 。 


| Dw (ww (B — Qor CSRS 
TRD wiw mco Ww w WO) 490) WACG) wncmn Who 
C geraden mthin 78 


























"vob MA 4 MA. ML M. RU. SHE v. Co Wm ness 
25507 dau [/Ag v te "m 





MIO n vn Ari we oe) 


v BJ Eius 
"Qo Www 

















3-20 ”创建 空白 网 页 








- ui : 
" 
PHP+ 


(2) 单 击 选择 滋 单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 
“数据 库 ” 面 板 。 在 “数据 库 ” 面 板 上 单 击 选择 “+” 图 标 ， 并 NEN 
在 打开 的 菜单 中 选择 “MySQL 连接 ”选项 ， 如 图 3-21 所 示 。 

(3) 在 “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 | ” i hime kuowcm. 
webconn、“MySQL 服务 右 ” 名 为 localhost、“ 用 户 名 ”为 root. 
密码 为 admin， 如 图 3-22a 所 示 。 选 择 所 要 建立 连接 的 数据 库 名 图 3-21 XPE MySQL 连接 
称 ， 可 以 单 击 “选取 ”按钮 ， 浏览 MySQL 服务 左上 的 所 有 数据 库 。 选 择 刚 寻 入 的 范例 数据 
JÆ phpweb， 具 体 的 设置 内 容 如 图 3-22b 所 示 。 














下 FYSQL 连接 











连接 名 称 : webconn 
MySQL 服务 器 : localhost 
HAPA: root 
JY, oekkk 
数据 库 : phpweb 


















































图 3-22 设置 MySQL 连接 参数 


(4) 早 击 “测试 ”按钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 人 确 ， 则 出 一 个 
消息 枉 ， 如 图 3-23 所 示 这 表示 数据 库 连 接 设 置 成 功 。 - 

单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ?” 
面板 中 则 显示 绑 定 过 来 的 数据 库 ， 如 图 3-24 Br. 

在 建立 完成 MySQL 连接 后 ， 在 “文件 夹 ” 面 板 中 会 
看 到 Dreamwaver 目 动 建立 了 Connections 文件 夹 ， 在 该 文 图 3-23 设置 成 功 
件 夹 下 有 一 个 与 前 面 所 建立 的 MySQL 连接 名 称 相同 的 文件 ， 如 图 3-25 所 示 。 




















文件 jiRil 
gre BE e phpweb v 本 地 视图 v 
二 一 THA. PHP C R) c | AQ | = 











=] webconn. ph 1KB PHP XU 
: A Ta age (tinyint 4] To index. php B JEETHESUE 
M us: ID (int 11 必需 的 ) E 
ines Hh mame ivar char 20) 
CE ow Hh Result [lvarchar 20) 
a A 视图 
田 … 半 ”预存 过 程 
< 山 > 
(Q ec 





图 3-24 SEXE 图 3-25 目 动 生成 的 文件 
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Connections 文件 夹 是 Dreamweaver 用 来 存放 MySQL 连接 设置 文件 的 文件 来。 打开 该 文 
件 并 使 用 “代码 ”视图 ， 可 以 看 到 连接 数据 库 的 设置 ， 如 图 3-26 所 示 。 
Dw | ws | i Oc cr 


WH 编辑 (EF) 查看 (VY) HAM 修改 (格式 名 ) 命令 (C5) 站 点 (5) 窗口 (由 8H) 
C:\Apache\htdocs\phpweb\Connections\webconn. php i 








&oo0»nag|m 


D 


?php 
2 # FileName=" Connection php mysql.htn" 
# Type-"MYSQL" 
# HTTP="true" 
$hostname webconn = "localhost"; 
$database webconn = "phpweb"; 
$username webconn - "root"; 
$password webconn = "admin"; 
$webconn = mysql pconnect($hostname webconn, $username webconn, $password webconn) or 
trigger error(mysql error(),E USER ERROR); 
?> 





« B) t3) (Ez) [«] $e [4] mx Iam 


1 K/1 $9 Unicode (UTF-8) 


[Om] | 格式 中 | 无 ~) 类 BI 
Bi css ID) 链接 (L) 





TREE... 列表 项 目 « =) 出 | 
®© 1 个 本 地 项 目 被 选中 $ (HE) 








3-26 数据库 连接 设置 


在 这 个 文件 中 定义 了 与 MySQL 服务 器 的 连接 (mysql_pconnect Kr), GHA FA 


y 


$hostname: MySQL 服务 器 的 地 址 。 

$database: 连接 数据 库 的 名 称 。 

$username: 用 户 名 称 。 

$password: HP i. 

XE XJ 4E 53 E Bu EKES ran Pr EE ELIO] NLIS A aA H ERU mysql_connect 与 数据 
库 连 接 。 连 接 后 才能 对 数据 库 进 行 得 询 、 新 增 、 修 改 或 删除 的 操作 。 

如 果 在 网 站 制作 完成 后 将 文件 上 传 至 网 络 上 的 主机 衬 间 时 ， 发 现 网络 上 的 MySQL 服务 
器 访问 的 用 户 名 、 密 人 码 等 方面 与 本 机 设置 有 所 不 同 ， 可 以 直接 修改 位 于 Connections 文件 夹 
下 的 webconn.php 文件 。 




















检查 数据 库 记录 





本 小 节 将 介绍 在 Dreamweaver 中 与 检查 数据 库 记 录 相 关 的 “服务 器 行为 ”主要 包 
括 记 录 集 、 插 入 记录 、 更 新 记录 、 重 复 区 域 、 显 示 区 域 和 记录 和 集 分 页 等 常用 的 动态 服务 
8811 NJ « 
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创建 记录 集 ) 

在 每 个 需要 奋 看 数据 库 记 录 的 页 面 中 缘 须 为 其 建立 一 个 “记录 集 《〈 碍 询 )”， 从 而 可 以 让 
Dreamweaver 知道 ， 目 前 这 个 网 页 中 所 需要 的 是 数据 库 中 的 哪些 数据 。 即 便 需 要 的 内 容 一 
样 ， 在 不 同 网 页 也 需要 单独 建立 。 同 一 个 数据 库 只 需 建 立 一 次 MySQL 连接 ， 但 可 以 为 同一 
个 MySQL 数据 库 连 接 建立 多 个 “记录 集 ”， 配 合租 选 的 功能 ， 达 到 茶 个 记录 集 只 包含 数据 
库 中 符合 某 些 条 件 的 记录 。 

打开 index.php 文件 后 ， 选 择 末 单 栏 上 的 “应 用 程序 ”一 “ 绑 定 ”和 面板 ， 选 择 “ 记 录 集 
(查询 )” 便 可 以 建立 记录 集 。“ 应 用 程序 ”一 “ 绑 定 ”面板 中 的 “记录 集 (查询 )” 与 “服务 
器 行为 ”面板 中 的 “记录 集 ” 是 相同 的 。 如 图 3-27 所 示 。 



































LE 一 文档 类 型 : PHP 
记录 集 ( 查询 ) 


表单 变量 
UL 变量 
阶段 变量 
Cookie WE 
服务 器 变量 
环境 变量 


Spry 数据 集 
获 职 数据 源 ... 





图 3-27 选择 “记录 集 ” 命 令 





按说 明 设 置 各 项 如 图 3-28 PIR, Wan AA MA” JE, Dreamweaver 会 显示 日 
前 设置 所 返回 的 记录 集 内 所 有 记录 。 字 段 的 功能 说 明 如 表 3-5 所 示 。 





表 3-5 字段 与 功能 说 明 


字 R 说 ”有明 
名 称 一 般 用 Recordset (记录 集 ) 的 缩写 rs 作为 开头 
连接 选择 所 建立 记录 集 的 数据 库 是 在 哪个 MySQL 连接 
列 此 处 显现 该 数据 库 连 接 中 所 有 的 数据 表 ， 以 及 所 选 数据 表 内 所 有 字段 
ffr zE fi A US AE T EH Ae io 
排序 是 否 依照 某 个 字段 值 进行 排序 。 比 如 ， 在 新 闻 系 统 中 需要 把 新 的 新 闻 放 到 前 面 位 置 ， 就 可 以 
使 用 排序 的 功能 











EKE EW” EHAKE SELECT 语句 ， 因 为 全 询 出 来 的 结果 可 能 会 有 很 多 条 ， 
所 以 称 为 “记录 和 集 ( 合 )”， gf "juve" S WD WHERE Tfj. 
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名 称 : |Rsdb| 
连接 : webconn 
表格 : |websql 
5.0 全 部 O mm: 








图 3-28 设置 “记录 集 ” 


单 击 “测试 ”按钮 后 ， 可 以 看 到 返回 的 记录 。 因 为 没有 做 任何 科 选 的 处 理 ， 所 以 会 返回 
完整 的 所 有 记录 ， 如 图 3-29 所 示 。 


测试 56L 指 仿 








Eu 
Ei 


testB 
testT 
testā 
test 
testlü 


= n co —1 cn (n a4» 603 P3 一 


= np co —1 cn (n 4» 63 To 一 m 
e 


e 


piest (P2 下 25 个 H) 





图 3-29 单 击 “测试 ”按钮 浏览 记录 和 集 


可 以 单 击 “高 级 ”按钮 查看 该 SQL 语句 。 可 以 看 到 ，Dreamweaver 提供 了 一 个 基本 的 
图 形 界 面 ， 实 际 上 它 会 生成 相应 的 程序 代码 。 在 “高 级 ”窗口 中 可 以 看 到 相应 的 SQL iE 
AJ WAI 3-30 所 示 ， 男 外 还 提供 加 入 变量 、 修 改 SQL 语句 的 功能 ， 用 以 满足 使 用 简单 图 形 
界面 设置 无 法 满足 的 情况 。 

在 记录 集 建 立 完 毕 后 ， 可 以 在 “应 用 程序 ”一 “ 绑 定 ”面板 中 得 看 到 目前 页 面 里 的 所 有 
记录 集 ， 以 及 各 记录 集中 的 字段 ， 双 击 记 录 集 可 以 重新 打开 图 3-31 所 示 的 设置 窗口 。 
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: 


: |webeorm 

















: |SELECT * 
FROM websql 




















添加 到 SQL: 
Cmm) 


WHERE 


ORDER BY 

















图 3-30 “高 级 ”记录 集 窗 口 图 3-31 绑 定 的 记录 集 效 果 


建立 记录 集 与 直接 写 SELECT 语句 是 相同 的 ， 将 页 面 切换 到 “代码 ”视图 ， 如 图 3-32 
所 示 。 其 中 第 1 行 的 require once 函数 是 用 来 引入 文件 的 ， 即 前 面 介绍 过 的 webconn.php。 
在 Dreamweaver 中 ， 帮 是 已 经 定义 好 数据 库 连 接 ， 那 么 在 其 他 建立 记录 集 、 更 新 记录 、 插 入 
记录 、 删 除 记录 的 页 和 面 中 ， 这 个 连接 设置 文件 就 会 在 页 面 的 最 前 面 被 引入 《这 束 是 为 什么 在 
同一 个 站 点 中 只 需要 定义 一 次 MySQL 数据 库 连 接 )， 因 为 该 文件 中 所 包括 的 与 数据 库 连 接 
相关 的 设置 需要 被 使 用 。 


























"5. C: ipacheWhtdocsVphpweblindez.php (XIHTIL)# -0x 
CHAED webconn. php T 
r3 1 <?php require once('Connections/webconn.php']); ?> ^ 
- BENE ov» J 
3 if (!function exists("GetSQüLValueString")) ( 
4 function GetSQLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "") 
o EAM 
+». BE if (PHP VERSION < 6] { 
= 7 $theValue = get magic quotes gpcí() ? stripslashes($theValue) : $theValue; 
* EE: } 
9 
e B $theValue = function exists("mysql real escape string") ? mysql real escape string($theValue) : mysql escape string( 
全 $theValue); 
TL 
| 起 | n switch ($theType) { 
— B case "text": 
Sg 14 $theValue = ($theValue != "") ? "'" , $theValue . "'" : "NULL"; 
RS break; 
fo) l6 case "long": 
— Bg case "int": 
(3 l8 $theValue = ($theValue !- "") ? intval($theValue) : "NULL"; 
Bt break; 
(5 20 case "double": 
cg $theValue = ($theValue !- "") ? doubleval($theValue) : "NULL"; 
AED break; 
& ER) case "date": 
dh, 24 $theValue = ($theValue !="") ?» "'" , $theValue . "'" : "NULL"; 
25 break; 
2s ae case "defined": — 
+= ad $theValue = ($theValue !- "") ? $theDefinedValue : $theNotDefinedValue; 
ES break; 
& 29 
30 return $theValue; 
31 
32 } 
34 mysql select db($database webconn, $webconn); 
5 $query Rsdb - "SELECT * FROM websql"; 
36 $Rsdb = mysql query(s$query Rsdb, $webconn) or die(mysql errorí)): 
EE Srow Rsdb = mysql fetch assoc($Rsdb): 
$tntralRowa Radh = mvarrl num rnwaí$Randh!: v 
3K/1 fb Unicode (UTF-8) 











3-32 BEI 
其 程序 具体 分 析 如 下 。 
(1) 第 34 行 引用 了 webconn.php 内 的 设置 (变量 $datebase_webconn 与 $webconn 被 定义 在 这 
个 文件 中 ) 来 选择 数据 库 (mysql_select db0)， 随 后 的 mysql_query() 所 作用 的 都 是 此 数据 库 。 
(2) 第 35 行 定义 了 查询 数据 库 的 SQL 语句 。 














:*3u56 Dreamweaver +PHP RF EHEH 








(3) 第 36 行使 用 第 35 行 所 定义 的 SQL 语句 对 数据 库 执 行 租 询 操作 (mysql_queryO )， 
此 时 返回 结 末 是 资源 标识 和 侍 ， 还 不 能 被 使 用 。 

(4) 第 37 行将 前 面 查 询 的 结果 以 关系 型 数组 的 形式 (mysql_fetch_assoc()) 传 到 变量 
$row_Rsdb， 然 后 融 可 以 使 用 $row_ 记录 集 名 称 [学 段 名 称 '] 来 取得 记录 集 字 段 值 。 | 

(5) 第 38 列 取 得 查询 结果 的 记录 条 数 Cmysgl num_rowsO0 )， 并 赋 给 变量 $totalRows — B 
Rsdb 。 

(6) 最 后 mysql free result FE JA & vy zi R d H BRA EE SER o 

上 面 是 Dreamweaver 连接 数据 库 并 执行 得 询 的 标准 步骤 ， 在 mysql query($query. Rsdb, 
$webconn) or die(mysql_errorO) 的 部 分 ， 寿 or 前 和 面 语句 出 现 铺 误 或 失败 ， 就 执行 or 后 面 的 程 
序 。 所 以 者 数据 库 得 询 失 败 的 时 候 了 驶 会 产生 错误 信息 ， 并 终止 程序 的 运行 。 

在 一 般 PHP 程序 中 ， 典 型 的 连接 与 得 询 程序 类 似 下 面 的 例子 。 






































mysql select db($database webconn, $webconn); 

$query_Rsdb = "SELECT * FROM websql"; 

$Rsdb = mysql query(Squery. Rsdb, $webconn) or die(mysgql error()); 
$row Rsdb = mysql fetch assoc($Rsdb); 

$totalRows Rsdb = mysql num rows(SRsdb); 

mysql free result($Rsdb); 











可 能 会 觉得 Dreamweaver 产生 出 来 的 程序 代码 比较 复杂 ， 这 是 因为 Dreamweaver ££ 
的 记录 集 需 要 搭配 很 多 服务 器 行为 来 使 用 。 


Seo 显示 记录 功能 
接 独 要 将 记录 集 内 的 记录 《〈 即 数据 库 中 的 数据 ) 直接 显示 到 网 页 上 ， 实 现 的 步 又 如 下 。 


CD 在 “文件 ”面板 中 打开 index.php， 在 网 页 中 制作 一 个 如 图 3-33 所 示 的 2x4 表格 ， 
然后 在 “应 用 程序 ”一 “ 绑 定 ”面板 ， 选 择 所 需 的 字段 并 拖 动 到 表格 中 。 









































A C: hpachevht docsAphpwebvindex, php (XHTML) * zm 
CHAED webconn.php T 
PHP 动 态 系统 

me RE ipe 成 项 
| (Rsdb.ID] | (Rsdb.name) (Rsdb. age) (Rsdb. Result) 
body? [Kn (RIS Q 100$ v646 x 254v 4 K / 1 $5 Unicode (UTF-8) 














图 3-33 SEE 


(2) 在 使 用 鼠标 拖 动 字段 全 页 面 上 放 开 后 ， 会 出 现 {Rsdb.name} 的 字样 ， 其 中 Rsdb 为 记 
KRAP, name 为 字段 名 称 。 将 序号 、 姓 名 、 年 龄 、 成 绩 4 个 字段 分 别 拖 全 相应 的 单元 格 





IPHP+ 


后 ， 单 击 | 实时 视图 | 按钮 。 
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视图 所 呈现 的 效果 与 使 用 浏览 如 打 开 网 页 一 样 ， 原 本 仪 显 示 { 记 录 集 名 称 .字段 名 称 } 的 部 








分 将 会 显示 出 记录 和 集 内 的 记录 ， 如 图 3-34 所 示 。 





Dw | wn | ET O um 
文件 (7) 编辑 (EF) 查看 (VY) 插入 (I) ERM 格式 (0) 命令 (C5) ”站 点 (5S) 窗口 (加 RH) 


indez. php X C: \Apache\htdocsiphpwebiindez. php 


Phat webconn. php 
| RE [ii [iR] RB A (EWWE] &E 0 OLARE C 标题 neo 
oC Ome/noommmiem OOOO E 


PHP 动 态 系统 














[一 HT | E | E 
| 1 test1 | 21 | 100 








& Gios59:8|7 


日 © 站 点 - phpweb (C... 
四- Connections 
775 add php 
P del. php 

<body. ca? <table> <tbody> <tr> <td> <a> 100% ~|678 x 382v 4 K / 1 f» Unicode (UTF-8) sT detail. php 

T5, index.php 

o update. php 








图 3-34 ”实时 视图 效果 





(3) 再 单 击 一 次 | 实时 视图 | 按钮 ， 将 页 面 切换 到 | 代码 视图 ， 可 以 看 { 记 录 集 名 称 .字段 名 


称 } 部 分 的 代码 ， 在 该 程序 代码 中 使 用 echo 来 输出 字段 值 ， 如 图 3-35 所 示 。 








Dw | wir ”| © cue 
AEG 编辑 (EF) 查看 (VY) 插入 (IT) EHM RAO 命令 (5C) 站 点 (3) gO ARH 


indez.php* X C: XApachekht docskphpweb*indez. php 


HAD webconn. php 


(FB | 设计 | | 实时 代码 LV A RNE | 检查 N Qo 多 屏 大 |v 0 00 dme pe 
i & o C ay Hu: £i1e:///C |/Apache/htdocs/phpweb/index.php 
58 <table width-"600" border="1" align-"center" cellpadding-"l" cellspacing-"1"» 
<tr> 
<t 中 序号 < jtq> 
«toS ca 
<td 年 龄 < /td> 
<t 中 成 绩 < /tq> 
x/tr» 
<tr> 
<td><a e S AA ee l a a > 
<td><?php echo $row Rsdb['name']; ?></td> 
<td><?php echo $row Rsdb['age']; ?»2«/td» 
<td><?php echo $row Rsdb['Result']; ?2«/td» 
</tr> 
</table> 
<hr /> 


artic | ETE 
&cdjoorae|m: 








mysql free result($Rsdb); 
?- 


Connections 
; add. php 
o del. php 


4K/1 f? Unicode (UTF-8) J Bn 
CT index.php 


L. © update. ph 
eoz y] x v| B7 BSSsasan|]  — is 
bcs o mo 链接 中 — à oD Hio i 
国 单元 格 KFU ~v aw) | mao WREeO OLI — | [ m 
一 oğ ampu ~v o | saw € sx 




















3-35 代码 视图 效果 
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c 重复 区 域 功能 : 


现在 只 能 看 到 记录 集中 的 第 1 条 记录 ， 那 后 面 的 记录 如 何 显示 出 来 呢 ?Dreamweaver t > 








供 了 “重复 区 域 ” 及 “记录 集 分 页 ”的 功能 ， 只 需要 鼠标 拖 动 ， 就 可 以 实现 这 个 功能 。 
选取 需要 重复 的 部 分 ， 即 表格 中 的 第 2 行 ， 如 图 3-36 所 示 ， 然 后 在 “服务 器 行为 ” 面 
板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 于 单 中 选择 “重复 区域” 命令 ， 如 图 3-37 Bp. 

















显示 区 域 
显示 记录 计数 d 
动态 女 本 


插入 记录 












更 新 记录 

册 除 记录 

动态 表单 元 素 d 
PHP 动 态 系统 用 户 身份 验证 d 


XSLT 转换 


编辑 服务 器 行为 . .. 
新 建 服务 器 行为 . .. 
获 职 更 多 服务 器 行 汶 ... 



























| (Rsdb.ID) (Rsdb.name) (Rsdb.age) (Rsdb. Result) 








图 3-36 选取 表格 第 2 行 图 3-37 选择 “重复 区 域 ”命令 


之 所 以 要 确认 选取 的 标签 为 <e ， 是 因为 重复 区 域 会 使 用 do...while 循环 包围 所 作用 
的 范围 。 而 需要 重复 的 仅 是 第 2 行 的 表格 ， 在 HTML 中 表格 的 行 是 使 用 str> 标 签 。 确 认 选 取 
的 标签 正确 ， 执 行 时 才 不 会 发 生 错 误 。 

此 时 会 弹出 一 个 窗口 ， 如 图 3-38 所 示 ， 要 求 选 择 要 重复 记录 的 记录 集 ， 以 及 需要 重复 
儿 条 记录 或 显示 全 部 记录 。 同 样 地 选择 | 实时 视图 |， 这 时 就 可 以 看 到 原来 只 有 两 行 的 表格 已 经 
增长 到 6 行 ， 如 图 3-39 所 示 ， 而 记录 集 内 的 前 5 条 记录 都 已 显示 在 页 面 上 。 
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图 3-38 设置 重复 区 域 图 3-39 ”实时 预览 效果 
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所 有 页 面 上 的 “服务 器 行为 ”都 会 被 列 在 “窗口 ”一 “服务 器 行为 ”面板 的 清单 中 ， 在 
本 例 中 ， 选 择 重 复 5 条 记录 。 若 想 要 修改 服务 器 行为 的 设置 ， 则 可 以 通过 双击 该 服务 器 行为 
来 进行 ， 如 图 3-40 所 示 。 


复 区 域 (Rsdb) 


sdb. Name) 
(Rsdb. Age) 
(Rsdb. Result) 








3-40 ”服务 器 行为 面板 


将 页 面 切换 到 “代码 ”视图 ， 在 套用 了 “重复 区 域 ”服务 器 行为 后 ， 在 程序 代码 当 
中 的 变化 便 是 这 行 单元 格 的 上 下 被 do...while 循环 包围 了 ， 而 重复 的 条 件 为 第 87 行 语句 
如 图 3-41 所 示 ， 用 这 样 的 循环 可 以 达到 将 记录 集中 的 记录 全 部 输出 才 停止 循环 。 


DW | mum [5 — —] Q ove [S]e ess 


ES TERE SEn E Emm 8x00) ROO MAE ”窗口 (9) Mhon 
CA gachalhi dcs phus indar 











ena RHEINE 





动态 文本 (Ridb Name) 
STE  (Erdb Ago) 


Ca eaa- E echo frot Rsdb['ID']: Peai uE 
?php -Rsdb['ID'] / HEEE Medb. Rezult) 


zEdoxPphp echo $row Rsdo['Mame']: Per 
«tiüx"php echo £row Rsdb['Age']: Pared 
“tp echo prov Rsdb['Result!']; Yi /Ed 


ctable width-"6D0" borde 
£t» 
td widthe"1437» (8— TI j« ds 
ctd widthe"14375 [B — DI 3. / cin. 
ctd widthe"143*»( Fijet 


kel & € yng 商品 | 


e ^n 


ctd width=" ldg" [MaM «orn 


up o 
[= in 


50 datail. php 
^ ^ index php 
"US uwpdate. php 


LK G9. ERR 


va E:zcrigmmo O O 


d jou 目标 io) 








3-41 AXES 


在 建立 记录 集 时 就 知道 有 10 条 记录 都 在 记录 人 集中， 可 是 在 这 里 怎么 显示 了 5 条 记录 
Je? 回头 来 检查 下 代码 ， 如 图 3-42 所 示 。 























第 3 草 Dreamweaver+PHP 开 发 基础 





T C: ÀpacheNhtdoeztphpwebindez. php [ECHTML J -Dx 


EASP webconn.php 


$naxRows Rsdh = 5; i " 

$pageNum Esdb = 0; d 

if (issetís GET['pageNMum Rsdb']]) 1 — 
spageMum Rsdb = $ GET['pageNum Rsdb']; 1 


} b. 一 三 三 
$5tartRow Rsdb = gpageNum Rsdb * $maxRows Rs; 


mysql select db(S$database webconn, £$webconn):; 

$masery Bsdb = "SELECT * FROM websql"; 

$query limit Rsdb = sprintf("5s LIMIT $d, $d", $query Esdb, $startRow Esdb, 
emaxRows Rasdb); 

sRsdh = mysql_query {$query limit Esdb, $&webconn) or dieimysql errorií)]: 
grow Esdb = mysql fetch assoc(sRsdb]:; 


if jissetis BETI['totalBReyws Rsdb']3]) 1 
$toatalRows Rsdh = $ GET['totalRows Esdb!']; 
} else 1 
$all Esdb = mysql_query {$query Esdb]; 
$tatalRows Rsdbh = myvsqi num rowsisall ERsdb]; 
} 
$toatalPages Esdb = ceilistotalEows Easdb/gmaxREows Esasdb]-1:; 
»- 


- dp TerarireTTETTOTA 1- l.. 1 TiTTTA T Tm rr J JTTÀ7Ag TO — LITTCTUET 1 -=-= --- 一 = =-=- = l l! ITITI 





tr Keda 5 K7 1? Unicode (UTF-6) 


图 3-42 ”代码 窗口 





发 现 数据 库 查 询 语句 被 改写 过 ， 在 第 42 行 变量 $query_Rsdb 所 用 的 SQL 语句 是 以 前 介 
绍 过 的 ， 但 在 第 43 行 该 变量 会 放 到 字符 串 的 第 一 个 %s 位 置 处 ， 如 下 : 








$query_limit_Rsdb = sprintf("%s LIMIT 96d, %d", $query_Rsdb, $startRow. Rsdb, $maxRows Rsdb); 
由 上 述 代 码 可 知 ，%s 表示 字符 串 ， 后 面 两 个 %d 表示 数值 ， 所 要 代入 的 值 是 $startRow - 


Rsdb 与 $maxRows_Rsdb。$maxRows_Rsdb 这 个 变量 值 与 前 面 在 重复 区 域 所 选择 的 重复 5 条 
记录 是 同步 的 ， 可 以 看 到 第 34 行 定义 了 这 个 变量 的 值 。 

















$maxRows Rsdb = 5; 


可 以 知道 ，Dreamweaver 使 用 了 一 堆 变 量 来 记录 在 图 形 界面 中 所 选择 和 设置 的 值 ， 然 后 
使 用 LIMIT 子 句 来 做 到 一 次 显示 指定 条 数 的 记录 。 








enero 记录 集 分 页 功能 











上 一 市 已 经 浏览 到 记录 集中 的 第 1 一 第 5 条 记录 ， 那 么 剩 下 的 记录 如 何 显 示 ? PIT 
绍 记录 集 分 页 功能 的 实现 方法 。 

(1) 在 页 面 下 方 加 上 1x4 的 表格 ， 接 看 在 时 元 格 中 分 别 输入 [第 一 页 ]、[ 前 一 页 ]、[ 下 
一 页 ]、[ 最 后 一 页 ] 等 文学 。 便 用 鼠标 选取 [第 一 页 ]， 然 后 在 “服务 融 行 为 ”面板 单 击 
“+” 按 钮 ， 从 弹出 的 下 拉 沫 单 中 选择 “记录 集 分 页 ”一 “ 移 至 第 一 页 ”命令 ， 如 图 3-43 
Br 








PHP 









QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





(Dw 


indez.php* Xx 


"RE webconn. php 


| "| — — —] O cue = 


TF 编辑 (EF) ”查看 (VY) 插入 (IT) WER) 格式 (0) r$ (c) 站 点 (53) Aow AEB CH) 


C:\Apache\htdocs\phpweb\indez. php 


+ 一 TM. PHP 














R | 实时 代码 p? FA ANNE RE D O LRE C dE P a. 
I Q co £a c 地 址 : file:///C |/Apache/htdocs/phpweb/index. php 重复 区 域 








PHPE 动 态 系统 移 至 前 一 页 
移 至 下 一 页 显示 记录 计数 
移 至 最 后 一 页 动态 文本 


EEP 姓名 年 龄 成 绩 插入 记录 


HN 更 新 记录 


143=< 一 | lus ——— m 143» — ———AÀ es 册 | 除 记录 
| nn 
XsLT 转换 


编辑 服务 器 行为 . .. 
| ”新 建 服务 器 行为 . .. 
获取 更 多 服务 器 行为 ... 

















CC) 站 点 - phpweb (C. 
a- Connections 
: A add. php 
D del. php 
» detail. php 


<body. ca? <table> <tr> Kta) j nÀ index. php 


o update. php 
格式 F) x sj -E 
& CSS mt) X vx 链接 C) | 目标 (6) 
国 单元 格 KFORU v| aW 16 GAGO[] WRE&ODJ — O 
— oğ amigu vaw | to 





























3-43 ”设置 为 “ 移 至 第 一 页 ” 


(2) 在 弹出 的 对 话 杠 中， 选择 记录 集 ， 确 认 链 接 所 选 的 范围 ， 如 图 3-44 所 示 。 

(3) 分 别 为 [前 一 页 ]、[ 下 一 页 ]、[ 最 后 一 页 ] 套 用 “ 移 人 至 前 一 页 ”人 “ 移 全 下 一 页 “ 移 全 
最 后 一 页 ”的 服务 占 行 为 。 然 后 按键 盘 上 的 《F12〉 键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-45 
所 示 。 在 页 面 中 试 试 刚刚 完成 的 导航 条 ， 可 以 注意 到 网 址 后 面 加 了 pageNum_Rsdb 与 
totalRows Rsdb 两 个 URL 变量 ， 被 用 来 在 分 页 浏览 时 与 重复 区 域 服务 喜 行为 相 搭 配 。 





A PHP 动 态 系统 — Nicrosoft Internet Explorer 回回 凤 
文件 @) RED SEV REA IAM 8800 r7 
QAR- O- HAA DPsk ux e A- LBL 

地 址 0) &) http: //127.0. 0. 1/phpweb/index. php?pageNum Rsdb-O&totalRows Rsdb-10 v EJ PA HS Qr saaert G 

















姓名 
testl 
test2 
test? 
test4 
test5 


[前 一 页 





























链接 : | 所 选 范围 :“[ 第 一 页 ] 
ERR: Ce ~ 
































3-44 设置“ 移 全 第 一 页 ”对 话 框 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “记录 集 分 页 ”一 “记录 
集 导 航 条 ”命令 ， 来 快速 地 插入 本 范例 中 所 建立 的 记录 集 导 航 条 。 








Dao sp sos 








Dreamweaver+PHP 开 发 基础 








在 页 面 上 方 输入 “ 共 * 和 


第 * 笔 ”， 建 立 起 记录 集 导 航 条 ， 以 便 让 È 
用 户 了 解 有 多 少 页 记录 和 当前 正在 浏览 的 页 码 。 
(1) 将 插入 点 置 


于 “共有 ”和 “笔记 录 ” 之 间 ， 选 择 “服务 器 行为 ”面板 ， 单 击 “+; 
按钮， 从 弹出 的 下 拉 荣 


笔记 录 ， 日 前 查看 第 


单 中 选择 “显示 记录 计数 ”一 “显示 总 记录 数 ”， 然 后 同样 要 选择 记 
录 集 ， 如 图 3-46a、b 所 示 。 
GEO) wo Ww ero el 
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ed 从 名 D 





Tiks Name) 














显示 总 记录 数 
[(AIg Qm -eam 6x Wi (IF 
v BJ I1: uU 8 UR 

“QO BWw 


(ER. ) 











(2) 按 同 样 的 方式 ， 将 插入 点 置 于 相应 位 置 ， 依 序 加 入 “显示 起 始 记 录 编 号 ”及 “显示 
结束 记录 编号 ” 完成 后 页 面 如 图 3-47 所 示 。 


Dw | SiHB * 
IFN 


E oo WU) du) Mam gom WA 


OQ sue [ep] 
ERO ESD) 
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[LETT cheiht daripa E pe 
MS EE iib) v^ F = MEM AM S. Q. SRRjr io. Co wm one 


PHP AS 


HA (Erde TotalRecorde) 第 记录 ， 目 前 查看 第 isdb FiretRecord] € - E 
jiz " 


datail php 
WI 13S es See KI E Yaicede (UTF-Rl 2 index php 
` qwpdate. php 


= BJ Eju an| Ef 
"40 ERG 
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3-47 ”加 入 统计 记录 









H 


PHP 


完成 后 ， 当 浏览 该 网 页 时 ， 便 会 出 现 当前 共有 几 笔 记录 ， 以 及 目前 得 看 的 是 第 几 笔 一 第 
儿 笔 的 提示 文字 ， 如 图 3-48 所 示 。 
ETT = Hicrozoft Internet Explorer EER 
Tn Wan 查看 的 Ru IAT EOD a 
QE - O RAGGAR: t OG cc 
Hiro) CETME o.o. Lighpwabi index. pho? pagsfun XsdbsD&totilRors, Rsds1Q * Eus sm Qu ET | 


PHPZh;S E 





AFUE, EHESS -EE 
姓名 au 


testl 
testz 
test? 
test 
testo 





3-48 ”建立 导航 条 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “显示 记录 计数 ”一 “ 记 
录 集 导航 状态 ”来 快速 地 插入 本 例 中 所 建立 的 记录 集 导 航 条 。 





So 品 示 区 域 功 能 


在 第 一 外 上 的 [第 一 页 ] 与 [前 一 页 ] 的 文学 链接 是 没有 意义 的 。 下 面 我 们 就 来 处 理 这 个 问 














晤 ， 如 末 不 是 第 一 页 时 ， 显 示 [ 第 一 页 ] 与 [前 一 页 ]; 如 来 不 是 最 后 一 页 时 ， 显 示 [ 下 一 页 ] 与 
[最 后 一 页 ]。 

实现 该 功能 的 步骤 如 下 。 

(1) 选择 [第 一 页 ]， 在 “服务 需 行 为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 和 单 中 选 
择 “ 显 示 区 域 ” 一 “如 果 不 是 第 一 页 则 显示 ”命令 ， 如 图 3-49a 所 示 。 打 开 “ 如 果 不 是 第 一 
页 则 显示 ”对 话 框 ， 选 择 “ 记 录 集 ”Rsdb， 再 单 击 “确定 ”按钮 ， 如 图 3-49b 所 示 ， 然 后 为 
[前 一 页 ] 也 做 同样 的 设置 ， 即 可 完成 设置 。 
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训 果 不 是 第 一 页 则 显示 
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Dreamweave r+PHP 开 发 基础 





(20 选取 [下 一 页 ] 链 接 文 字 ， 在 “服务 需 行 为 ”面板 中 单 击 “+” 投 钮 ， 从 弹出 的 下 拉 
菜单 中 选择 “显示 区 域 ” 一 “如 末 不 是 最 后 一 页 则 显示 ”命令 ， 如 网 3-50 所 示 。 然 后 为 [最 
后 一 页 ] 也 做 同样 的 设置 。 








Dw | wm | [87] Q cue > 
W 编辑 (EF) 查看 (VY) 插入 (I) EHM ”格式 (0) 命令 (C) 站 点 (3) gow) BH) 





index. php* X C: NApachekht docsSphpwebXindez. php 
Dat webconn.php 





+ 一 文档 类 型 : PHP 
记录 集 
重复 区 域 
记录 集 分 页 











如 果 记 录 集 为 空 则 显示 
如 果 记 录 集 不 汶 空 则 显示 显示 记录 计数 
如 果 是 第 一 页 则 显示 HELE 


共有 (Rsdb.TotalRecords) 笔记 录 ， 目 前 查看 第 {Rsdb FirstRecord) 笔 至 第 (加 果 不 是 第 一 页 出 显示。 | anea 


姓名 年 龄 成 绩 E 更 新 记录 
re " 删除 记录 


如 果 符 合 此 条 件 则 明示 E r LEN | S E UR 

88 — B] : XSLT 转换 
编辑 服务 器 行为 .. 
BRIRA SEN... 

获 职 更 多 服务 器 行为 ... 




















件 
日 e 站 点 - phpweb (C... 
E- Connections 
| > add. php 
»| del. php 
cp detail. php 
body. ca? <table> <tr> <td> Ka) 678 x 382» 9 K / 1 $9 Unicode (UTF-8). | D) index.php 


» update. php 
(Omw] toz ~y) 类 | 无 yaBr 三 拭 此 此 标题 0[ —— 
Es moz v ED Cre rin Cavo 县 加 | v 
国 | šm KFORU ~v X00 | 143| TAGO[] WREeOIIJ —. ( mE 
— oğ ampu — v mo | saoo e 














3-50 ”设置 “如 朵 不 是 最 后 一 负 则 显示 ” 


G) 完成 后 在 每 个 套用 “显示 区 域 ” 的 “服务 器 行为 ”的 部 分 会 出 现 “如 末 符 合 此 条 件 
则 显示 …” 的 提示 文字 ， 如 图 3-51 所 示 。 








Dw | ae v | DT O cue 
TF 编辑 ([F) 查看 (Y) 插入 (IT) EAM A0 AS 站 点 (S) gow AER H) 


indez. php X C: XÀApachehht docskphpwebhindez. php 
ENA webconn. php 


ORBA | 设计 | | 实时 代码 EI 实时 视图 EE t OSRE C Ra P yag ma 
i G d tà c 地址 : £ile:///C |/Apache/htdocs/phpweb/index. php BIS ME dod) 
显示 结束 记录 编号 (Rsdb) 
PHP 动 态 系 统 重复 区 域 (Rsdb) 
动态 属性 (a href, $row_Rsdb[’ ID 
TM 动态 文本 (Rsdb. ID) 
H ETS : ISLE (Rsdb.name) 
HA (Rsdb.TotalRecords) 笔记 录 ， 目 前 查看 第 { 了 sdb FirstRecord) E ££ 58 (Rsdb.LastRecord) SE 动态 立 本 (Rsdb. age) 
动态 立 本 (Rsdb. Result) 
如 果 不 是 第 一 页 则 显示 (Rsdb) 
移 至 第 一 页 (Rsdb) 
是 第 一 页 则 显示 
FE ， | 如 果 符 合 此 条 件 则 显示 . SLIDE DILE eig nm (Rsdb) | 
[Bi — f DE [到 后 一 内]  AnSRERRE— TUR mem Y 
n— m 

















文件 
区]G@139 人 YY 名 图 | 四 


ft 
日 e 站 点 - phpweb (C... 
g. B Connections 
775 add. php 
del. php 
detail. php 


<body. ca? <table> Ctr? Kta) 100%  ~|678 x 382v 10 K / 1 $9 Unicode (UTF-8). index. php 


eoz v REO v BI EmnussD| —— 
En CSS noz «€ 0] — | v9 BRO 


| 下 eee GROS —— v|X€0| 143| WAGOD) EREeOII — ”| —( XEE|. 
一 oğ BOB vaw | sao € 


FEE! 


update. php 























3-5] EH “ERKE” AR 


(4) 最 后 按 〈F12》 键 ， 在 浏览 器 中 检查 输出 结果 ， 如 图 3-52 所 示 。 












PHP-* 
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E | PHP 动 态 系统 — Nicroso ft Internet Explorer DER) 
TFP AE SEV REAO IAT) 帮助 0) AN 


QAER- O- har yx € 8 Ec 


地 址 0) [Æ] http: //127. 0. 0. 1/phpweb/index. php?pageNun Rsdb-O&totalRows Rsdb-10 v 转 到 ”链接 Qn [ej 


PHP 动 态 系统 








共有 10 笔 记录， 目前 查看 第 1 笔 至 第 5 笔 
姓名 | 年 龄 


test 
test2 
test? 
test4 
test5 








图 3-52 ”设置 “显示 区 域 ” 后 的 效果 


也 可 以 在 Dreamweaver 菜单 中 选择 “插入 ”一 “数据 对 象 ” 一 “记录 集 (Recordset) 分 
页 ”一 “记录 和 集 导 航 条 ”命令 ， 来 快速 地 插入 一 个 分 页 区 域 。 





So 显示 详细 信息 | 


很 多 时 候 ， 并 不 会 开始 就 将 数据 库 所 有 子 段 、 记 录 部 显示 出 来 。 例 如 一 个 新 闻 系 统 ， 在 














首页 上 只 会 显示 新 闻 的 日 期 与 标题 ， 更 详细 的 新 闻 内 容 需 要 选择 标题 进入 到 另 一 个 页 面 才 能 显 
示 。 假 设 显示 新 闻 标 题 的 页 面 是 index.php， 而 显示 详细 狐 闻 内 容 的 网 页 名 称 为 detailphp。 当 
在 index.php 中 点 击 标题 的 链接 后 ， 此 时 该 超级 链接 会 市 看 一 个 参数 到 detail.php， 网 址 类 似 于 
detail.php?ID=1。 多 出 的 ID=1 是 一 个 变量 名 为 ID， 值 为 1 的 URL 参数 。 当 detail.php 收 到 
ID=1 的 URL 参数 后 ， 便 利用 这 个 URL. 参数 在 建立 记录 集 时 敌 选 所 指定 的 新 闻 记 录 ， 并 将 记 
录 详 细 信 息 显 示 在 网 足 上 。 这 样 就 构成 了 一 个 简单 的 新 闻 系 统 染 构 。 要 沛 选 指定 的 记录 可 以 在 
SQL 中 使 用 WHERE FAJ, Æ Dreamweaver 中 有 相应 的 图 形 界 面 可 以 方便 使 用 。 下 面 ， 看 看 
Dreamweaver 是 如 何 运 用 传送 与 接收 URL 参数 来 粒 选 出 指定 的 记录 。 

(1) 使 用 Dreamweaver 创建 一 个 空白 的 detail.php 页 面 并 保存 。 在 index.php 中 选择 要 用 
来 连接 到 话 细 信 息 页 面 的 部 分 《其实 残 是 选择 要 在 哪里 建立 超级 链接 )， 在 本 例 中 选择 序 
号 ， 即 选择 {Rsdb.ID} 动 态 文字 ， 如 图 3-53 所 示 。 
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图 3-53 ”选中 动态 文字 {Rsdb.ID)】 
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第 3 章 


(2) 在 下 面 的 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 口 ， 如 
图 3-54 所 示 。 




















mie | 
ERT 无 v 类 | 无 v| BI tiuindmo[ | 
Es css mt) X v) BEL) | vlelc ERE 





国 šm KFORU ë v N|) | 不 换行 0) 口 WARN&O!I E 页 面 属性 ，. 
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图 3-54 建立 链接 设置 


(3) 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 detail.php， 如 图 3-55 所 示 。 


选择 文件 名 自 : GG ERE 站 点 根 目录 
ORE 


3h aR SS S8... 








查找 范围 [): | (C) phpweb v €) 2 E? g- 


C) mmServerScripts 








.notes 
[Connections 


hc 


index.php 














XS 00: (detail. php 
MEREM): | 所 有 文件 Gon 

















VRL: detail. php 
相对 于 : | PE v | index. php 
在 站 点 定 必 中 更 改 默 让 的 链接 相对 于 














图 3-55 设置 链接 的 文件 
(4) 如 条 仅仅 是 这 样 ， 那 只 会 是 单纯 的 超级 链接 ， 并 没有 附带 URL 参数 。 因 此 ， 要 单 


击 “ 参 数 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 本 例 将 参数 名 称 命名 为 
ID， 在 设置 值 的 时 候 ， 单 击 如 图 3-56 中 上 鼠标 所 指向 的 图 标 。 





图 3-56 设置 参数 


(5) 选择 URL 参数 ID 所 要 带 的 值 ， 因 为 要 的 是 记录 集 ID 字段 的 值 ， 所 以 选择 ID 字段 


如 图 3-57 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 。 









7PHP-^ 





BR: | 无 v 





代码 :| 《<?php echo $row Rsdb[' ID ]; ?> 





3-57 选择 ID 字段 





除了 记录 集 字 段 外 ， 只 要 是 在 “ 绑 定 ”面板 中 所 建立 的 ， 包 括 表 单 变 量 、URL 变量 、 
Session 变量 和 Cookie 变量 等 ， 都 可 以 在 这 里 被 选择 。 

(6) 此 时 ， 可 以 看 到 超级 链接 的 地 址 变 成 detail.php?ID=<?php echo $row_ Rsdb['ID ]; ?>， 
如 图 3-58 所 示 。 
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图 3-58 ”完成 后 的 链接 地 址 


(7) 设置 完成 后 ， es index 页 而 。 可 以 看 到 ， 每 一 条 记录 的 链接 部 市 看 





QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 








URL 参数 DD， 其 值 是 每 条 记录 的 ID. Aul] 3-59 所 示 。 
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共有 10 笔 记录， 目前 查看 第 1 笔 至 第 5 笔 
姓名 年 龄 
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test2 
test? 
test4 
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图 3-59 ” 单 击 链接 的 属性 显示 
前 而 已 经 完成 了 index.php 中 应 该 完成 的 部 分 ， 下 面 来 看 看 接收 URL 参数 的 detail.php 
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如 何 用 收 到 的 参数 来 筛选 指定 的 记录 。 
(1) 打开 detail.php 页 面 后 选择 “ 绑 定 ” 面 板 ， 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选 

F WRR AW)” Mme, WME 3-60 rm. f 
(2) 则 会 打开 “记录 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 e 
1) 在 “名 称 ”文本 框 中 输入 rsdetail 作为 该 “记录 集 ” 的 名 称 。 rad 
2) 从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连 接 对 象 。 x 
3) M RR” FAIRER, EREA ERIA websql。 
4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 
5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参数 /ID。 
完成 后 的 设置 如 图 3-61 Brzn 


























E 
t 


+; — THEN. PHP ;: [rsdetail 





: webcorn 








记录 集 ( 查询 ) 


表单 变量 
UL 变量 
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Cookie f 
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Spry 数据 集 
区 了 数据 源 . 








:|websql 


:O em O wm. 












































图 3-60 选择 “记录 集 (查询 ) ” 图 3-61 设置 “记录 集 ” 对 话 框 


(3) 如 果 想 知道 SQL 语句 ， 可 以 日 击 “ 蜗 级 ”按钮 。 在 “局 级 ”界面 测试 SQL 语句 ， 
如 图 3-62 所 示 。 在 SQL 语句 中 的 colname 是 一 个 变量 ， 知 筛选 的 时 候 有 用 到 变量 ， 
Dreamweaver 就 会 用 这 个 变量 名 称 放 在 SQL 语句 里 。 而 这 个 变量 的 值 会 是 什么 呢 ? Nx I 
"变量 "区 域 中 colname 的 运行 值 的 定义 。 当 网 页 运作 时 ，colname 将 等 于 URL 变量 ID 的 值 
($_GET[TTD'])， 所 以 当 URL 变量 ID 值 不 同 ， 筛 选 出 的 结果 也 不 同 。 




















;; EEE 


: |j webconn 











: [SELECT * 
webs 








运行 值 : $ GET[ ID ] 














添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 




















* A 图 
zd. ”预存 过 程 








图 3-62 ”高 级 “记录 和 集 ” 对 话 框 
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(4) 然后 单 击 “ 确 定 ”按钮 ， 完 成 记录 集 建 这 。 记 录 集 建立 完毕 后 ， 可 以 把 各 个 字段 拖 
动 到 页 面 上 相应 的 单元 格 中 ， 如 图 3-63 所 示 。 以 上 详细 页 面 的 制作 融 算 大 功 告 成 。 


m C:NÁpachekhtdocziphpwebidetail.php (EHIML)s 


= 0X 
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T " 


[Wy 100 lest x eriv 4K/ 1 E Unicode WFE) 
图 3-63 制作 的 详细 页 面 


(5) 完成 后 直接 按 (F12) 键 在 浏览 器 中 打开 detailphp， 发 现 内 容 是 空白 的 ， 如 图 3-64 


所 示 。 这 是 怎么 回 事 呢 ? 因为 在 网 址 后 面 没有 带 看 URL 参数 ， 当 然 记 录 集 里 就 不 会 有 任何 
东西 。 
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更 新 / WR 














图 3-64 “显示 为 空白 


(60 直接 在 网 址 后 加 上 URL 变量 ID， 其 值 可 以 选 1 一 10 的 任何 一 个 值 ， 然 后 按 
(Enter〉 键 ， 网 页 显示 的 结果 如 图 3-65 所 示 。 
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图 3-65 URL 参数 ID=5 时 的 详细 页 面 
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(7) 在 index.php 中 ， 每 一 笔记 录 的 网 址 都市 有 特定 的 参数 链接 到 detail.php， 如 图 3-66 


所 示 。 


A PPAS% = Nicrosoft Internet Explorer DER) 
TH AHE EE EA IAM) #80 [7] 
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共有 10 笔 记录 ， 目 前 查看 第 1 笔 至 第 5 笔 
姓名 年 龄 

testl 21 

test2 

test3 

test4 

test5 























I^ | 12s. [Iw i d- : 


























Æ] http: //12T. 0.0. 1/phpweb/detail.php?ID-l p pna er 
图 3-66 单 击 首 页 上 的 链接 
(8) 单 击 第 1 个 链接 后 ， 打 开 指 定 记录 的 详细 页 耐 ， 如 图 3-67 所 示 。 


A 详细 页 面 一 Microsoft Internet Explorer 
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3-67 打开 指定 记录 的 详细 页 面 


_Section_ 





编辑 记录 功能 





前 面 介绍 了 如 何 将 位 于 数据 库 中 的 记录 拖 到 网 页 上 显示 。 本 节 将 介绍 新 增 、 更 新 以 及 删 


除 的 操作 。 





在 数据 表 websql 中 有 4 个 字段 ， 其 中 ID 字段 为 主键 且 附 加 了 auto. increment 属性 ， 


此 在 独 增 记录 时 不 必 考 虑 ID 字段 ， 只 和 需 增 加 3 EB. 









f zr 


实现 的 步骤 如 下 。 
(1) 创建 一 个 空白 的 php 网 页 ， 并 命名 为 add.phpp， 先 添加 一 个 表单 ， 再 插入 一 个 4x2 
表格 ， 键 入 相关 提示 后 依 序 放 上 3 个 文本 字段 、 两 个 按钮 ， 完 成 后 如 图 3-68 HR. 
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HE C: hpachevhtdoesAphpwebvadd php (XHTXL) -H 
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i 山 md 2 d 
RI Q 100$ 4530x229» 1 K / 1# Unicode (UTF-B) — -: 





图 3-68 建立 表单 并 设计 网 页 


当 需 要 新 增 、 更 新 记录 时 ， 网 页 中 需要 有 一 个 表单 且 表 单元 素 必 须 置 于 表单 内 ， 在 单 击 
按钮 后 ， 只 有 在 表单 内 的 元 素 会 被 以 POST 或 GET 的 方式 传递 。Dreamweaver 中 的 新 增 、 更 
新 记录 都 是 将 表单 元 素 的 值 以 POST 的 方式 传递 给 页 面 ， 当 程序 判断 到 指定 字段 〈 新 增 记 录 
F, FRAI MM_insert， 当 使 用 了 “插入 记录 ”服务 器 行为 时 该 字段 将 被 目 动 添加 〉 送出 
了 POST 信息 〈 值 为 窗 体 名 称 )， 便 执行 狐 增 、 更 独 记 录 等 部 分 的 程序 。 

(2) 插入 3 个 文本 字段 ， 并 分 别 选择 各 个 文本 字段 ， 并 在 “属性 ”面板 上 为 其 命名 ， 分 
别 是 姓名 Name, FH Age、 成 绩 Result， 注 意 在 设计 时 要 与 记录 集 字 段 名 称 一 一 对 应 ， 如 
图 3-69 所 示 。 
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图 3-69 命名 文本 域 








说 明 : 
当 表 单元 素 的 命名 与 记录 集 字 段 相 符合 上 时， 在 做 “新 增 记录 ”、“ 更 新 记录 ”时 ， 
Dreamweaver 会 自动 将 表单 元 素 与 记录 集 字 段 相 匹配 。 
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(3) 选择 “服务 器 行为 ”面板 ， 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 沫 单 中 选择 “插入 记 
K” A q^, 如 图 3- 70 所 示 。 


Dw Ce (SIME 


ZAT I) FEM MAM STOOD ROG GPO MAGO Wom 00 


omm pma DW] apes Et Sram mm M. d. £EE 
pO D m lE s T gash cu iib adl. phy 





body) (Ferniiforni) (tabla) (ur) (Li unsuuPEerult [Rh |i) CL 107€ AT dl 2 E 7 1 lnisade (UTF-R) 


| SH cya Osce OSB 
| js 





e 1 TXANBXST,S[BE.] 
3-70 ”执行 “插入 记录 ”命令 


(4) 打开 “插入 记录 ”对 话 框 ， 设 置 插入 记录 属性 ， 选 择 连 接 为 webconn， 插 入 表格 至 
websql， 这 是 设置 要 将 记录 添加 到 哪 一 个 数据 表 中 。 在 选择 完 数据 表 后 ,“ 列 ”区 域 中 便 会 
出 现 该 数据 表 内 的 所 有 字段 ， 可 以 在 这 里 设置 哪个 数据 表 字 段 要 从 表单 中 的 哪个 元 素 获 取 
值 ， 有 基体 的 设置 如 图 3-71 所 示 。 





























: 下 一 个 pJi: ER 
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插入 后 ， 转 到 : index.php 

















3-71 设置 “插入 记录 ”对 话 框 


说 明 : 

之 前 将 表单 元 素 的 命名 与 数据 库 字 段 名 称 相 同 ， 所 以 在 建立 “插入 记录 ”时 
Dreamweaver 便 会 自动 将 它们 配对 。 也 可 以 先 选 择 欲 设置 的 字段 ， 由 “ 值 ” 右 方 的 下 拉 式 菜 
单 中 选择 从 哪个 表单 元 素 取得 值 。 然 后 在 “插入 后 ， 转 到 ”的 文本 字段 框 填 上 index.php。 将 
表单 元 素 的 名 称 与 数据 库 内 的 字段 名 称 命名 为 相同 ， 除 了 “插入 记录 ”以 外 , “更 新 记录 ” 
服务 器 行为 也 会 将 相同 名 称 的 数据 列 与 表单 元 素 自动 配对 在 一 起 。 
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(50 设置 完成 后 ， 在 “服务 占 行 为 ”和 面板 的 列表 中 残 会 多 出 一 项 插入 记录 如 图 3-72 所 
示 ， 可 以 双击 该 项 重 靳 进行 “插入 记录 ”的 设置 。 完 成 后 网 页 上 的 表格 会 变 成 浅 绿色 的 撒 ， 
当然 这 并 不 是 表示 有 错误 ， 而 是 表明 该 表单 使 用 了 “服务 器 行为 "。 同 时 ， 在 表单 内 也 目 动 
加 上 了 和 名称 为 MM_insert 的 隐藏 字段 ， 用 来 判断 用 户 是 否 单 击 “提交 ”按钮 大 出 信息 ， 并 是 
侣 执行 “插入 记录 ”部 分 的 程序 代码 。 
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3-72 ”插入 记录 后 的 页 面 效 末 


(60 Aiz (F12) 键 在 浏览 器 中 打开 网 页 ， 输 入 值 如 图 3-73 所 示 ， 并 单 击 “ 提 交 ” 按 
钮 尝试 新 增 一 笔记 录 。 


A 添加 记录 一 Nicrosoft Internet Explorer 
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3-73 ”输入 记录 数据 


CI) 单 击 “提交 ”按钮 后 ， 网 址 将 从 add.php 转 全 index.php。 点 击 网 页 下 方 的 分 页 导航 
条 的 [最 后 一 页 ] 链 接 ， 便 可 以 看 到 刚才 新 增 的 记录 ， 如 图 3-74 Pm. 
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PHPZAISA SE 


共有 11 笔 记录， 目前 查看 第 11 笔 至 第 11 笔 
姓名 Fi? 


tegl! 25 





3-74 增加 记录 后 的 效果 

程序 说 明 : 

简单 地 来 看 看 这 部 分 的 程序 代码 是 怎样 的 。 表 单 的 “动作 ”为 <?php echo $editForm 
Action; ?> (如 图 3-75 所 示 )， 在 单 击 按钮 后 网 页 是 将 信息 以 POST 的 方式 送 给 自己 ， 所 以 先 记 
住 这 个 变量 后 切换 至 “代码 ”视图 。 在 “代码 ”视图 中 可 以 看 到 $editFormAction 变量 的 值 如 图 
3-75 所 示 ，$ SERVER 是 预定 义 变 量 的 一 种 ， 用 以 提供 服务 器 的 相关 信息 ; 而 
$_SERVER[PHP_SELE] 便 是 返回 该 网 页 的 文件 名 称 。 所 以 表单 的 "动作 "为 <?php echo 
$editFormAction; ?> 就 意味 着 ， 将 表单 数据 以 POST 方式 传递 给 自身 。 
性 


TE AE [Pohe echo jeüiomAetim; ?> |O BÉRD| č ? 
J 





3-75 ”表单 动作 参数 


接着 看 到 被 自动 添加 的 隐藏 字段 MM. _insert， 其 值 是 form1， 与 所 在 位 置 的 表单 名 称 一 
致 。 代 码 的 窗口 如 图 3-76 所 示 。 
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mysql select db(fdatabase webconn, fvebconn); meld, — 
£Resultl * mysql query(s;insert2JO0L, évebconn) or die([mysql, erroE()); | y] GLG 
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| M a 
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$insertboTo .e $ SERVER['OUERY STRING']: 
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图 3-76 ”代码 窗口 
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核心 的 代码 说 明 如 下 : 


if ((üsset($ POST["MM. insert"])) && ($ POST["MM insert"] == "form1")) { 








/判断 表单 变量 $_ POST['MM_insert] 是 否 被 设置 ， 且 值 是 否 等 于 forml1。 如 果 是 ， 则 执行 下 面 的 插 


入 记录 动作 。 
$insertSQL = Sprintf("INSERT INTO websql (Name, Age, "Result ) VALUES (96s, 96s, 96s)", 
/定义 了 SQL 语句 。 
GetSQLValueString($_POST['Name'], "text"), 
GetSQLValueString($_POST['Age'], "int"), 
GetSQLValueString($ POST['Result'], "text")); 
/ 取 值 表单 的 变量 。 


mysql select db($database webconn, $webconn); 
$Resultl = mysql query(SinsertSQL, $webconn) or die(mysgl error()); 
/连接 数据 库 执 行 SQL 语句 。 
$insertGoTo = "index.php"; 
/设置 了 在 "插入 记录 "后 要 跳 转 的 文件 index.php， 它 被 存储 在 变量 $insertGoTo。 


更 新 记录 功能 是 指 将 数据 库 中 的 旧 数 据 根 据 需要 进行 更 新 的 操作 。 这 里 会 用 前 面 已 经 使 
用 到 的 detail.php 文件 。 

更 新 记录 功能 的 操作 步骤 如 下 。 

(1) 打开 detail.php 网 页 后 ， 选 中 “更 新 ” 如 图 3-77 所 示 。 
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3-77 选择 链接 文字 


(2) 在 “属性 ”面板 中 ， 单 击 如 图 3-78 所 示 的 “浏览 文件 ”图 标 ， 为 其 建立 附带 URL 
参数 的 超级 链接 。 
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| [e] 单元 格 KF gs Bu — A sameo [IE 
— qme BOE — veo | OL) 


x 3-78 "Hub "fp" BER 


(3) 输入 用 来 更 新 记录 使 用 的 update.php HA, RER BAO HL JJESGENDAE 
为 ID， 值 是 rsdetail 记录 集 ID FRE URL 参数 ， 如 图 3-79 所 示 。 


站 点 根 目录 
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图 3-79 ”选择 文件 并 设置 参数 


(4) 单 击 “ 人 确定” 按钮 ， 完 成 后 的 链接 地 址 : 
update.php?ID=<?php echo $row. rsdetail['ID']; ?>// 传 递 ID 到 update.php 页 面 ， 如 图 3-80 


所 示 。 
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3-80 传递 ID 至 update.php 


(5) 创建 update.php 文件 。 开 始 的 操作 与 乙 前 在 制作 记录 详情 页 面 detail.php 时 相同 ， 
部 是 利用 接收 到 的 URL. SAINE WRK. Æ ERTA” WP, Ari +” H, M 
RERI PARERE RR AAW)” MS, WE 3-81 所 示 。 
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3-81 选择 “记录 集 (查询 ) ” 


(6) 打开 “记录 和 集 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 rsupdate 作为 该 “记录 集 ” 的 名 称 

20 从 “连接 ”下 拉 列 表 框 中 选择 “webconn” 连 接 对 象 。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 和 象 为 websql。 
4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参数 / ID。 
完成 后 的 设置 如 图 3-82 所 示 。 





















































3-82 ”设置 “记录 和 集 ” 对 话 框 








(7) 将 页 面 中 应 该 有 的 表单 、 文 本 字段 、 按 钮 设 年 完成， 在 “ 绑 定 ”面板 中 将 记录 集 内 
的 字段 拖 动 至 页 面 上 各 对 应 的 文本 字段 中 ， 如 图 3-83 所 示 。 
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图 3-83 HEFE 
(8) HF ID 是 主键 ， 不 能 随便 变更 主键 的 值 ， 因 此 选择 ID 部 分 的 文本 字段 ， 单 击 忌 标 
右键 ， 从 弹出 的 快捷 染 单 中 选择 “编辑 标签 (input)” 命 令 ， 如 图 3-84 所 示 。 
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图 3-84 设置 “编辑 标签 ”命令 
(9) Æ WM AP, WE RR” RAH, WK 3-85 所 示 。 通 过 这 样 的 设置 ， 这 
个 字段 便 不 能 被 用 户 修改 。 
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3-85 设置 为 “只 谈 ” 属 性 
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(100. 然后 再 单 击 “ 服 务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “更 
新 记录 ”命令 ， 如 图 3-86 所 示 。 
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3-86 执行 “更 新 记录 ”命令 











C1) 打开 “更 新 记录 ”对 话 框 ， 设 置 更 新 记录 的 参数 。 选 择 “ 连 接 ”webconn 后 ， 
个 表单 元 素 与 字段 都 会 目 动 匹配 好 ， 只 需 在 “在 更 狐 后 ， 转 到 ”输入 框 填 上 index.php. JU 
图 3-87 所 示 。 





| fora! 





;Dowebconn 





|websql 


TD” 使 用 :FORMI ID 
^ name I , 


EN ' EA 
M FORM. Nane’ RIAT 
, age 从 ' F0 


Mie, BROTO LM 


'Result' M 





(B: | FORM. ID 
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在 更 新 后 ， 苇 到 : 





index.php 











3-87 ”设置 “更 新 记录 ”参数 





(12) 蛙 击 “确定 ”按钮 ， 完 成 后 页 面 的 表格 同样 会 被 侠 上 浅 绿色 的 压 ， 而 表单 中 也 会 
多 出 一 个 隐藏 字段 ， 名 称 为 MM_update， 值 与 表单 名 相同 ， 如 图 3-88 所 示 。 


(13) 最 后 在 浏览 器 中 打开 index.php， 选 择 最 后 一 笔记 录 到 详情 页 面 detail.php， 然 后 在 
详情 页 面 选择 “更 新 ”链接 ， 如 网 3-89 所 示 。 
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图 3-88 ”完成 的 页 面 效 果 
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(14) 在 update.php 中 可 以 修改 姓名 、 年 龄 与 成 绩 的 字段 值 ， 而 ID 文本 子 段 是 不 能 被 修 
改 的 。 更 改 完成 后 ， 单 击 “ 更 新 ”按钮 ， 如 图 3-90 Br. 
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3-90 ”修改 数据 












"PHP 


返回 到 index.php， 检 和 碍 该 笔记 录 是 否 被 正确 更 新 ， 如 图 3-91 所 示 。 
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图 3-91 完成 更 新 的 功能 页 面 


这 部 分 的 程序 代码 与 插入 记录 基本 相同 ， 关 别 只 在 于 隐藏 字段 的 名 称 不 同 ， 使 用 的 是 
UPDATE 语句 。 





EC E 删除 记录 功能 


删除 记录 功能 是 指 将 数据 从 数据 库 中 删除 ， 使 用 “服务 器 行为 ”中 的 “删除 记录 ”命令 
即 可 以 实现 。 

有 具体 的 实现 步骤 如 下 。 

(10 HERR wA URL 参数 转 到 删除 页 面 delphp。 首 先 在 detail.php 中 选中 “ 删 
ER". 在 “属性 ”面板 中 建立 链接 ， 如 图 3-92 rn. 
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3-92 设置 “删除 ”链接 


(2) 因为 删除 记录 还 是 依据 主键 的 ID 子 段 ， 故 选择 删除 记录 所 用 文件 del.php， 并 附 市 
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| | Dreamweave r+PHP 开 发 基础 





URL 参数 ， 其 名 称 为 ID， 值 为 rsdetail 记录 集 的 ID 字段 值 ， 如 图 3-93 所 示 。 


WeEGDUREB: XR 站 点 根 目录 
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w Ce 
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在 站 点 定 必 中 更 改 默 认 的 链接 相对 于 








3-93 ”设置 传递 的 参数 属性 


(3) 单 击 “ 确 定 ” 按 钮 ， 这 样 就 完成 了 detail.php 的 修改 工作 ， 接 下 来 开始 修改 
del.php。 创 建 del.php 文件 ， 在 “ 绑 定 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 沫 单 中 选择 
“记录 集 (查询 )” 命 令 ， 如 图 3-94 所 示 。 
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图 3-94 ”选择 “记录 集 (查询 ) ”命令 





(4) 打开 “记录 和 集 ” 对 话 杠 ， 在 该 对 话 框 中 进行 如 下 设置 。 
D 在 “名 称 ” 文 本 框 中 输入 rsdel 作为 该 “记录 集 ” 的 名 称 。 
20 从 “连接 ”下 拉 列 表 框 中 选择 webconn 连接 对 象 。 












PHP+MySQL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 websql。 
4) 在 “ 列 ” 单 选 按 钮 组 中 选择 “全 部 ” 单 选 按钮 。 

5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 ID=URL 参数 /ID。 
完成 后 的 设置 如 图 3-95 所 示 。 








到 3-95 设置 “记录 集 ” 对 话 框 
(5) 将 各 个 记录 集 字 段 拖 动 到 页 面 中 所 对 应 的 文本 框 后 ， 将 “删除 ”按钮 命名 为 Del, 
接着 在 “服务 器 行为 ”面板 中 单 击 “+” 按 钮 ， 从 弹出 的 下 拉 菜 单 中 选择 “删除 记录 ” 命 
令 ， 如 图 3-96 所 示 。 
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图 3-96 选择 “删除 记录 ”命令 
(6) 在 弹出 的 “删除 记录 ”对 话 框 中 ， 进 行 如 图 3-97 所 示 的 设置 。 














首先 检查 是 否 已 定 只 变量 ; 











: |websql 
:|ID v 数值 
: [URL 参数 ~| [ID 


册 除 后 ， 转 到 : index.php 


























3-97 设置 “删除 记录 ”对 话 框 


“主键 列 ” 与 “主键 值 ”所 设置 的 是 删除 记录 的 依据 ， 这 里 的 依据 是 指 在 DELETEFORM 
数据 表 WHERE 条 件 里 的 条 件 ， 假 设 条 件 是 WHERE ID=11， 相 应 地 ， 可 以 看 成 WHERE 主键 
列 = 主 键 值 。 在 这 里 并 不 一 定 要 选择 数据 库 中 的 主键 来 当做 主 索引 键 字段 。 

C7) 单 击 “确定 ”按钮 完成 设置 。 

至 此 ， 己 经 学 习 了 最 基本 的 Dreamweaver 内 置 服务 右 行 为 ， 并 有 日 了 解 了 其 源 程序 代码 的 
意义 。 在 后 面 各 章节 中 的 模版 系统 ， 如 用 户 管理 系统 、 留 言 管理 系统 、 新 闻 管 理 系统 等 ， 都 
将 用 到 这 些 操作 。 
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用 户 管 理 系统 是 PHP WFE P E HARRER, A H P TERI 
统 ， 一 般 应 该 有 用 户 注册 功能 、 资 料 修 改 功能 、 取 回 密码 功能 ， 以 及 用 户 注销 喘 份 等 功能 。 
本 章 将 前 面 介 绍 的 知识 加 以 灵活 应 用 ， 在 实例 中 主要 用 到 创建 数据 库 和 数据 库 表 、 建 立 数 据 
源 连 接 、 建 立 记 录 集 、 创 建 各 种 动态 页 和 面 、 添 加 重复 区 域 来 显示 多 条 记录 、 页 面 乙 间 传 递 信 
县 、 创 建 寻 航 条 、 隐 藏 导航 条 连接 等 技巧 和 方法 。 








MATIE E 


HFA NAR: 


(7 用 户 管 理 系 统 网 站 结构 的 搭建 

O 创建 数据 库 和 数据 库 表 

(— 建立 数据 源 连 接 

O 掌握 用 户 管 理 系 统 中 页 面 之 间 信 息 传 递 的 技巧 和 方法 
(7 用 户 管 理 系 统 常 用 功能 的 设计 与 实现 
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用 亡 管 理 系统 的 规划 


在 制作 网 站 的 时 候 ， 一 般 部 要 在 制作 之 前 设计 好 网 站 各 个 页 面 之 间 的 链接 关系 ， 绘 制 出 
系统 脉络 图 ， 以 便 后 面 整个 系统 的 开发 与 制作 。 


系统 结构 设计 


“用 户 管理 系统 ”的 系统 结构 如 图 4-1 所 示 。 本 系统 主要 的 结构 分 成 用 户 登 录 蛋 块 与 找 
加 密码 修改 资料 模块 两 个 部 分 ， 其 中 index.php 是 这 个 网 站 的 首页 。 


用 户 管理 系统 
用 户 登 录 模 块 找 回 密码 修改 资料 模块 


loginfail.php welcome.php 
lostpassword.php userupdate.php 


新 用 户 注册 页 面 


register.php showquestion.php userupdateok.php 
regfail.php regok.php showpassword.php logoot.php 


图 4-1 系统 结构 图 


在 本 地 计算 机 设置 站 点 服务 器 ， 在 Dreamweaver CS 5.5 的 网 站 环境 除了 按 (F12〉 键 来 
浏览 网 页 之 外 ， 还 可 以 在 正 浏 览 器 输入 “http:/localhostymembervindex.php” 来 打开 用 户 系统 
的 首页 index.php， 其 中 member 为 站 点 名 。 


页 面 规划 设计 


用 户 管理 系统 的 主要 结构 分 为 用 户 登 录 和 找 回 密码 修改 资料 两 个 部 分 ， 整 个 系统 共有 
12 个 页 面 ， 各 个 页 面 的 名 称 和 对 应 的 文件 名 、 功 能 如 表 4-1 所 示 。 




















表 4-1 用 户 管理 系统 网 页 设计 表 


页 面 名 称 E 能 

index.php 实现 用 户 管 理 系 统 登 录 功 能 的 页 面 
welcome.php 用 户 登 录 成 功 后 显示 的 页 面 
loginfail.php 用 户 登 录 失 败 后 显示 的 页 面 
register.php 狐 用 户 用 来 注册 输入 个 人 信息 的 页 面 


regok.php 狐 用 户 注册 成 功 后 显示 的 页 面 
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(BE) 
页 面 名 称 功 能 
regfail.php 狐 用 户 注 册 失 败 后 显示 的 页 面 
lostpassword.php 丢失 密码 后 进行 密码 查询 使 用 的 页 面 
showquestion.php 伍 询 密码 时 输入 提示 问题 的 页 面 
showpassword.php 答对 查询 密码 问题 后 显示 的 页 面 
userupdate.php 修改 用 户 资 料 的 页 面 
userupdateok.php 成 功 更 新 用 户 资料 后 显示 的 页 面 
logoot.php 退出 用 户 系 统 的 页 面 


创建 用 户 数据 库 











通过 对 用 户 管理 系统 的 功能 分 析 发 现 ， 这 个 数据 库 应 该 包括 注册 的 用 户 名 、 注 册 密 码 以 
及 一 些 个 人 信息 ， 如 性 别 、 年 龄 、E-mail、 电 话 等 。 所 以 在 数据 库 中 必须 包含 一 个 可 容纳 上 
述 信息 的 表 ， 称 之 为 “用 户 信息 表 ” 将 数据 库 命 v member， 接 下 来 要 在 MySQL 建立 网 
站 数据 库 作 为 得 询 、 痢 增 、 修 改 与 删除 任何 数据 的 后 站 文 持 。 制 作 步 又 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", YEA MySQL 数据 库 的 管理 面 
板 ， 如 图 4-2 所 示 。 

(2) Hat LH) Create 增加， 按钮， 并 在 打开 的 下 拉 有 末 单 中 侍 击 选择 “Database 
(数据 库 )” 命 令 ， 如 图 4-3 Drm. 



















EüL Nannger 2007 for ESL BEI d 
gswem MN; Toon amem Pun Lem indo Hee 
E HON: 1 x zm B 5 i TRANNE TA 
Eg em Started 
ie c ale rere He 


T" hianage existing databasn(s) 








Database Tools " 
" WEW 
B Execute E script | 
QE Manage users Eu Procedure 
Help and Support | A 
Function 
i) Sg Manager 2007 halp syste | 
mr J Scheduled Event 
E77 m Irnerriet Resources LIDIF 
E fj SQL Manager 2007 home page d. Support Certe | 
LH DUAL Monge SED! enc liis: docurnentahion Ll CLA Non SEIL, FAL 
而 Favorite Gluery 
图 4-2 打开 MYSQL 数据 库 K|4-3 单 击 选择 “DataBase” 


(3) 打开 “Create DataBase Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“member”， 再 单 击 Next( 下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 4-4 所 示 。 

(4) 设置 MySQL 数据 库 的 属性 设置 如 表 4-2 所 示 ， 连 接 设 置 如 图 4-5 所 示 ， 然 后 再 单 
ii Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 
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Create Database Wizard 


Create Database 


Specify the name for a new database 


Welcome ta the create Database Wizard! 
This wizard allows vou to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SaL statement for creating the database and execute it 
on Mysia server. 


LONE 


Register after creating 


Database name 





图 4-4 输入 数据 库 的 名 称 member 


表 4-2 数据 库 属性 设置 


User name root 
Password admin 


Create Database Wizard 
Create Database 


Set connection properes for a new database 


localhost v Port 3308 —7 
User name ragt 


senes [OOO [Bem setna 
awn OOOO 


[ ]use tunneling 


Host name 


Password 


Tunneling 


SSH tunneling HTTP tunneling 


Ceea] ene) on] 


K|4-5 连接 设置 





用 户 管理 系统 开发 





(50 打开 新 建 数据 库 的 SQL 语句 所 示 ， 创 建 数据 库 member， 百 接 单 击 Next (下 一 步 ) 


按钮 ， 如 图 4-6 所 示 。 








动态 网 站 建设 从 入 门 到 精通 


Create Database Wizard 


Create Database 


Hesult SQL statement. Click the Finish button to create a new database. 


l soL 


— Manager 
—— tor MySQL 





Result SoL statement:: 
CREATE DATABASE `rmember'`; 


Click "Finish" ta create the databaze. 


Cancel 


4-6 完成 设置 


(6) 单 击 Finish〈 完 成 ) 按钮 ， 打 开 注 册 数 据 库 的 设置 画面 ， 选 择 utf8 FIR, AP 
文 版 的 GB2312 版 ， 其 他 的 则 保持 默认 值 ， 如 图 4-7 所 示 。 


Database Registration Info 


$^ Connection 


4l | Display Options 
(= Directories 


e SSH Tunneling 
HTTP Tunneling 
HH Data Options 


Connection 


Host name 
User name 
Passwword 


Database name 
Database alias 


Client charset 


Eont charset 





4-7 ”选择 简体 中 文 版 


CI) Hah OK (确认) 按钮， 完成 数据 库 member 的 新 增 工 作 。 

数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 管理 员 
数据 admins 及 用 户 数据 member。 建 立 数据 表 后 ， 接 着 再 单 击 左边 的 “Connect to Database 
(连接 数据 库 )” 图 标 站 将 其 连接 上 。 这 两 张 数据 表 的 字段 结构 内 容 说 明 如 下 。 


























C1) 建立 数据 库 member 后 ， 用 鼠标 右键 单 击 选择 Table 
(表格 ) 选项 ， 在 打开 的 豆单 中 单 击 选择 “New Table Cr 
格 )” 命 令 ， 如 图 4-8 所 示 。 

(2) 数据 库 右 方 画 面 会 出 现 新 建 数 据 表 (Table) 的 设置 区 
hk, 含有 “Table (表格 )”“Fields CA", “DDL (驱动 )”3 
个 选项 卡 。 先 在 “Table (表格 )” 中 输入 数据 表 名 member, Al 
图 4-9 所 示 。 

(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 
域名 以 及 设置 数据 域 位 的 相关 数据 ， 如 图 4-10 所 示 。 


£ Jable — [member] — [member on localhost] 


Object ^ | Properties | Fields | Indices | Triggers | Data | Dependencies | DDL 
| [3 member on localhost [n v Table name member 


| EF member v | Storage Options 


























Storage engine MyISAM 
cn SEI Row format DYNAMIC 
[a] Refresh | Min. rows 
学 Compile 图 = : Max. rows 
Qs Grants on table : 


























Auto increment value 








DE - Average row length 
@) Show SQL help 了 


d Table Editor options 
回 Restore default size 








*»&»*€»«»/«» 


Size for index key blocks 
[C] Check sum [C] Delay key write 
[ ]Pack keys Temporary 











Tools 





Character Sets |File Options | Merge Table Options | Federated Table Options 








E | Truncate table 
Character set utf 


( Collation utf8. bin 
4-9 输入 数据 表 名 member 




















£ Table - [member] - [member on localhost] 








: Mew Table... Ctrl+M 


Refresh Tables Es 


Database Registration Info... 


4j New Tab from Here... 
Rename Current T ab... 
Delete Current T ab 
Find Item... Ctrl+F 





图 4-8 开始 建 数据 表 


Gexum O O 


DEK) 








Object Al | Properties | Fields | indices | Triggers | Data | Dependencies | DDL | 





Field Name Field Type Size ^ Precision Not Null Default 


Comment 





| [3 member on localhost [n v 








go O NEGER  " 0 Null 








| 国 member v | 


username VARCHAR 20 Null 








password [VARCHAR 20 Null 


- 





question VARCHAR 50 Null 





(g) Refresh answer VARCHAR 50 Null 








mammam 


学 Compie truename |VARCHAR — (50 Null 








[| Bis Grants on table sex VARCHAR Null 





address VARCHAR Null 





éa Print 


@) Show SQL help tel VARCHAR 


Null 





QQ [VARCHAR Null 


dh Table Editor options 





email VARCHAR Null 


cO ococococoooocoi'ioco 


回 Restore default size 





Null 

















II L3 E ETE EST 


authority CHAR 








| 
W7474 * 4 4 3 3 4 4 3 9 3 34 34 * 33 * * * 
OOO EE aa a a 


Tools 


E Truncate table 


Sg Add new field 
E4 Edit selected field 
Eg Drop selected field(s) 














图 4-10 设置 数据 库 





各 字段 如 表 4-3 所 示 。 这 个 数据 表 主 要 是 记录 每 个 用 户 的 基本 数据 、 加 入 的 时 间 ， 以 及 


登入 的 账号 与 密 公 。 
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表 4-3 member 数据 表 


字段 名 称 TRES TRAG 


ID 1 


3 


N 
© 


username varchar 


N 
© 


password varchar 


cA 
© 


question varchar 


LA 
© 


answer varchar 


truename varchar 


© 


sex varchar 


CA 
© 


address varchar 


cA 
© 


tel varchar 


QQ varchar 


cA | N 
© | © 


email varchar 


O 
a 
= 


— N — 


authority 
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HET 
用 户 编号 
用 户 账号 
用 户 密码 

找 回 密码 提示 

答案 
真实 姓名 
姓 别 
m 


也 可 以 直接 在 DOS 的 MySQL 输入 管理 状态 下 直接 创建 数据 表 ， 实 现 的 命令 如 下 : 


CREATE TABLE member ( 
"ID? int(11) NOT NULL AUTO INCREMENT, 
"username" varchar(20) COLLATE utf8 bin NOT NULL, 
"password: varchar(20) COLLATE utf8 bin NOT NULL, 
"question" varchar(50) COLLATE utf8 bin NOT NULL, 
"answer varchar(50) COLLATE utf8 bin NOT NULL, 
‘truename varchar(50) COLLATE utf8 bin NOT NULL, 
“sex varchar(10) COLLATE utf8 bin NOT NULL, 
"address varchar(50) COLLATE utf8 bin DEFAULT NULL, 
"tel varchar(50) COLLATE utf8 bin DEFAULT NULL, 
‘QQ varchar(20) COLLATE utf8 bin DEFAULT NULL, 
"email varchar(50) COLLATE utf8 bin DEFAULT NULL, 
"authority, char(1) COLLATE utf8 bin NOT NULL, 
PRIMARY KEY CID) 


) ENGINE=MyISAM AUTO INCREMENT-2 DEFAULT CHARSET-utf8 COLLATE-utf8 bin; 


定义 member 丫 点 


在 Dreamweaver CS 5.5 中 创建 一 个 “用 户 管 理 系 统 ” 网 站 站 点 members， 由 于 这 是 PHP 


数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 4-4 所 示 。 


表 4-4 站 点 设置 的 基本 参数 
站 点 名 称 members 


本 机 根 目 录 C:\Apache\htdocs\members 
测试 服务 器 C:\Apache\htdocs\ 
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CBE) 
网 站 测试 地 址 http;//localhost/members/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataMySQL\MySQL Server 5.5\data\member 
管理 账号 / 密码 root / admin > 
数据 库 名 称 member 





创建 members 站 点 具体 操作 步骤 如 下 。 
(1) 首先 在 CAMApacheWMtdocs 路 径 下 建立 members 文件 夹 ， 如 图 4-11 所 示 ， 本 章 所 有 


建立 的 网 页 文件 都 将 放 在 该 文件 夹 下 。 
mwC- Apachevhtdocs RD) 
ar 


WHFP Aa EOD 收藏 以 ) IAM BH) 
QEB- Od ORR (xtX | 回 - 
地 址 部 ) c C: SApachekhtdocs v 转 到 


文件 和 文件 任务 ”人间 A Wb 区 shop 
1 KB 
wj Eder 
PE DE: | 
D ext P 
Q srtxsscema 
pg 共享 此 文件 到 
以 电子 邮件 形式 发送 
该 文件 来 内 的 六 御 
X 出 除 这 个 文件 到 











[^ Apache 

C) 我 的 文档 
gi 共享 文档 
q 我 的 电脑 
G 网 上 邻居 


EE 1 THR PE i 


4-11 建立 站 点 文件 夹 members 








(2) 运行 Dreamweaver CS $.$， 和 选择 菜单 栏 中 的 “站 
点 ”一 “管理 站 点 ”人 命令， 打开“ 管理 站 点 ”对 话 框 ， 如 

















图 4-12 所 示 。 
(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 em 

定义 的 站 点 。 单 击 右边 的 “新 建 ” 按 钮 ， 打 开 “ 站 点 设置 对 

象 ” 对 话 框 ， 进 行 如 下 参数 设置 : 
“让 点 名 称 ”: members. 


“本 地 站 点 文件 夹 ” C:\Apache\htdocs\members\。 

如 图 4-13 所 示 。 

(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [ 主 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 4-14 所 示 的 参数 设置 。 

“服务 占 名 称 ”: members. 


4-12 “管理 站 点 ”对 话 框 
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“连接 方法 ” 本 地 /网 络 。 
“服务 器 文件 夹 ” C:\Apache\htdocs\。 
“Web URL”: http://localhost/。 


[P-h-4 wk WA nenbers 
Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 


站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 到 web 上 的 服务 器 上 的 远程 文件 来 。 


您 可 以 在 此 处 当 Dreamweaver 站 点 选择 本 地 廊 件 夹 和 名 称 。 
站 点 名 称 ; 
本 地 站 点 次 件 夹 ; | Capache\htdocstmembers 一 





图 4-13 新 建站 扣 参 数 设置 


站 点 设置 对 甸 members 








[mE = EX i] 
服务 器 名 称 
服务 器 文件 | - 
webun 











取消 





图 4-14 设置 “基本 ”选项 卡 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 步 
信息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL， 表 示 是 使 用 PHP FF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 4-15 所 示 。 

(6) 单 击 “ 保 在 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 按钮 ， 
如 图 4-16 所 示 。 


























用 户 管 理 系 统 开 发 


设置 来 自 
版 本 控制 
^» EE [V 维护 同步 信息 
口 保存 时 自动 将 文件 上 传 到 服务 器 
口 自用 文件 职 出 功能 
区 打开 文件 之 前 职 出 
取出 名 称 : | | 


电子 邮件 地 址 8000000000000 | 








E EI Web JEX 





4-15 设置 “局 级 ”选项 卡 


HARKAS. members 
mu USE 
您 将 在 此 位 置 选择 承载 Web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 


Internet 服务 提供 商 (ISP) 或 web 管理 员 。 








注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 web 并 发 
布 页 面 ， 您 只 需 定 以 一 个 远程 服务 器 即 可 。 


| 连接 | 远程 EUN 
members CifApache/htdocs ZH Mw M 








4-16 WE “Ri” Z% 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 
才 所 设置 的 站 点 members。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 以 上 束 完 成 了 
Dreamweaver CS 5.5 测试 用 户 管 理 系 统 网 页 的 网 站 环境 设置 。 


dues | 设置 数据 库 连 接 


完成 了 站 点 的 定义 后 ， 接 下 来 就 是 用 户 系 统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 
连接 设置 如 下 。 
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(1) 将 光盘 中 设计 的 本 半 静 态 文 件 复制 到 站 点 文件 来 下 ， 打 开 index.php， 如 图 4-17 
pi 





Dw | eB v| O) Oow COES 
XO) 编辑 (E) 查看 (Y) 插入 (D 修改 M) 格式 (0) 命令 (C) 站 点 (S) IQ ERCH) 


index.php X C: \Apache\htdocs\member\indez. php 3 


€ EP mymember. php 
; niin 本 地 视图 vw 


i Go C 位 Wii: |£i1e:///C |/Apache/htdocs/member/index.p 














c 
由 -onsia tions 


images 
[is = © index.php 
T5 loginfail. php 


) logoot. php 


| 
[ e» lestpassword... 
de es En 
E»] es c regfail.php 
/oo E 3B m register.php 





5 regok php 
À showpassword... 
v» showquestion... 
»  wuserupdate.php 
特别 bem 5 userupdateok... 
= welcome. ph 
j| |, TRIS: SEEL i00, SERES, I4 TE 
METRAR FEH, 外 观 美 等 特点 。 
Eftr: 旺 2480 
会 员 价 : ¥ 2180 


EX 
| p 
861 x 365v 111 K / 3 f? Unicode (UTF-8) 





格式 [X v 
v 


E css ID(I) | 无 














mmt... 列表 项 目 








4-17 打开 index.php 


(2) 单 击 选择 沫 单 栏 上 的 “窗口 ”一 “数据 库 ” 命 

， 打 开 “ 数 据 库 ” 和 面板 。 在 “数据 库 ” 和 面板 上 ， 单 击 选 
M “+” 图 标 ， 并 在 打开 的 来 单 中 选择 “MySQL 连接 ” 
选项 ， 如 图 4-18 所 示 。 

(3) Æ “MySQL 连接 ”对 话 框 中 ， 输 入 的 “连接 名 
称 ” 为 mymember, “MySQL 服务 器 ”名 为 localhost, 
“HPZ” XÑ root， 密 人 码 为 admin 如 图 4-19a 所 示 。 选 择 
所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 , 浏 06018 W MySQL i 
w MySQL 服务 右上 的 所 有 数据 库 。 选 择 刚 导入 的 范例 数据 库 member， 其 体 的 设置 内 容 如 
图 4-19b 所 示 。 











连接 名 称 : mymember [db shop - 
information schema 
MySQL 服 劳 器 : localhost 


7 mysql 
用 户 名 : root i performance schema 




















IJA: Goeekek 




















数据 库 : member 

















4-19 设置 MySQL 连接 参数 
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(4) 单 击 “ 测 试 ” 按 钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 ， 则 会 出 现 
一 个 如 图 4-20 所 示 的 消息 框 ， 这 表示 数据 库 连 接 设 置 成 功 。 

单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 4-21 所 示 。 





HEF | Sp | 服务 器 行为 | E 
* 一 TEŽU: PH C 


E (3 mymember 
日 脚本 编制 














am membe 
m, address (varchar 50) 
LEO m, answer (varchar 50 必需 的 ) 
下 75QL 连接 : m, authority (char 1 必需 的 ) 
m, email (varchar 50) 
连接 名 称 : Ue ID Gat 11 必需 的 ) 
vex. B&B S epic S 
HPZ: Ta question (varchar 50 必需 的 ) 
sia. p sex (varchar 10 必需 的 ) 
tel (varchar 50) 
数据 库 : m, truename (varchar 50 必需 的 ) 
: m, username (varchar 20 必需 的 ) 
Ag 视图 
k 预存 过 程 
图 4-20 设置 成 功 图 4-21 显示 绑 定 的 数据 库 





用 户 登 录 模块 的 设计 


本 市 主要 介绍 用 户 登 录 模 块 的 制作 ， 在 该 模块 中 将 进行 登录 的 用 户 称 为 会 员 ， 所 以 界面 
中 显示 的 是 “会 员 登 录 ” 了 字样 。 


LUUD 登录 页 面 的 设计 : 


在 用 户 访问 该 用 户 管理 系统 时 ， 首 先 要 进行 身份 验证 ， 这 个 功能 是 靠 登 录 页 面 来 实现 
的 。 所 以 登录 页 面 中 必须 有 要 求 用 户 输入 用 户 名 和 密码 的 文本 框 ， ee 
录 的 “登录 ”按钮 、 和 输入 错误 后 重新 设置 用 户 名 和 密码 的 “ 重 置 ” 按 钮 。 详 细 的 制作 步骤 
如 下 。 

(OD 首先 ， 来 看 一 下 用 户 登 录 系 统 的 首页 设计 ， 如 网 4-22 所 示 。 

(2) index.php 页 面 是 用 户 登 录 系 统 的 首页 ， 打 开 前 面 所 创建 的 index.php 页 面 ， 输 入 网 
页 标题 “PHP 用 户 管 理 系统 ”然后 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 网 页 标题 保存 。 

G) 执行 菜单 “修改 ”一 “页 面 属 性 ”命令 ， 然 后 在 “背景 颜色 ”文本 框 中 输入 颜色 值 
为 #CCCCCC， 在 “上 边 距 ”文本 框 中 输入 0 像素 ， 这 样 设置 的 目的 是 为 了 让 页 面 的 第 一 个 
表格 能 置顶 到 上 边 ， 并 形成 一 个 灰色 底 纹 的 页 面 ， 设 置 如 图 4-23 所 示 。 

(40 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 进 入 “文档 ”窗口 ， 执 行 菜单 “插入 记录 ”一 
“表格 ”命令 ， 在 打开 的 “表格 ”对 话 框 中 ， 在 “ 行 数 ”文本 框 中 输入 需要 插入 表格 的 行 数 
为 3， 在 “ 列 数 ” 文 本 框 中 输入 需要 插入 表格 的 列 数 为 3。 在 “表格 宽度 ”文本 框 中 输入 775 
像素 ,“ 边 框 粗细 ”“ 单 元 格 边 距 ” 和 “单元 格 间 距 ” 都 为 0， 如 图 4-24 所 示 。 
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3 PHP 用 户 管理 系统 一 Microsoft Internet Explorer TBR) 
THF 9:800 查看 人 WOO 工具 (T) # H) Ld 


QmB-O-[9igtf Pss g4wuex e e- ABL 
地 址 0m) [Æ] ctp: //127.0.0. 1/menber/ —Wocueger w Ejus s Qs E 
mE 


RUP SUED ERE a (e WEST A ] 


"€ EN] os 


购物 中 心 会 员 登录 客户 留言 联系 我 们 











^ 





| 特别 推荐 





产品 说 明 : 三 星 智能 手机 , 100 万 像素 , 支持 号 3、 肛 4 
和 蓝 和 下 技术 . 手 与 功能 , 外 观 美 等 特点 。 


ea : — | 忧 惠 价 : Y 2480 
: : EEE f 会 员 价 : v2180 


;注册 新 用 户 找 回 密码 























联想 手提 电脑 
本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 为 
初次 接触 动态 网 站 开发 的 读者 而 写作 。 


pn EE: 
Amf: vs 
购物 流程 

|o LB | 

2. 确 定 订购 gy 产品 说 明 : 具有 624I0 处 理 器 和 5 英 十 各 损 屏 玫 以 及 可 

3. 网 上 付款 | JESIQWERTT P498 2 BEEF LAC 00 — REP RP BILE. : 
4185/88 : Hafi: Y 10588 
' 会 员 价 : ¥ s80 


Copyright 8 2011 HBCulture .com Inc. All rights reserved. 环 博 交 化 版 可 所 有 
M Internet 





4-22 用 户 登 录 系 统 首页 


外 观 (css) 


Ni) Z 00 加 ez 
AG 

文本 颜色 mm: [l| | 

FRM B): [Mecce | 

青 只 图 像 D:[ | [| 


zs. 


AAE M) : | |e 
LiB) o | | TAE | |o 





4-23 “页 面 属性 ”对 话 框 
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TA 列 : 
II 
过 框 粗 细 : 0 (f 

单元 格 过 距 ， E BE 
单元 格 间距 : 0 — E 





图 4-24 设置 “表格 ”属性 


(5) 单 击 “确定 ”按钮 ， 这 样 就 在 “文档 ”窗口 中 插入 了 一 个 3 行 3 列 的 表格 。 将 鼠标 
放置 在 第 1 行 表 格 中 ， 在 “属性 ”面板 中 单 击 “ 合 并 所 选单 元 格 ， 使 用 跨度 ”按钮 图 标 
In KE 1 行 表格 合 并 ， 再 执行 菜单 “插入 记录 ”一 “图 像 ” 命 令 ， 打 开 “ 选 择 文件 ”对 
话 框 ， 在 站 点 images 文件 夹 中 选择 图 厂 01.gif， 如 图 4-25 所 示 。 











XCEEET fS CE 
选择 立 件 名 目 : © THA ELSE 

Otis 站 点 和 服 邯 器 .. 
SRED: .一 二 p m 


SENE 
"joz. E 


- — o— 
ry t r mrs 53 Lat p a 
: aeto PEE T TATE r, 
FEE TE -1 
= REMIT m 
rt pr" "me nan Ewa 





IE Ta GIF, 62 K / 2 


TFM T: ERIE (* gifi*. jpgi*. jpegi*. png; 六 * 


URL: images/Ūl. gif 


相对 于 : Ard | index.php 


在 站 点 定 亿 中 更 吃 黑 让 的 链接 相对 于 
预 点 图 者 





图 4-25 “选择 图 像 源 文件 ”对 话 框 


(6) 单 击 “ 确 定 ” 按 钮 ， 就 在 表格 中 插入 了 此 图 片 ， 将 鼠标 放置 在 第 3 行 表格 中 ， 在 
“属性 ”面板 中 单 击 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 图 标 | 回 |， 将 第 3 行 所 有 列表 格 合 
并 ， 再 执行 菜单 “插入 记录 ”一 “图 像 ” 命 令 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 站 点 images 
文件 夹 中 选择 图 片 05.gif， 插 入 一 个 图 片 ， 效 果 如 图 4-26 所 示 。 














f zv 


Tic: NApachexXht docsymemberkindez. php* SII 


Gi EE 
TES "b Ss TN, 








E-— me 
[RI 1008 v85 x 311v 86 K / 2 Unicode (IIT-8) a 
4-26 插入 图 片 效 未 图 


CD 插入 图 片 后， 选择 插入 的 整个 表格 ， 在 “属性 ”面板 上 “对 齐 ” 下 拉 列 表 框 中 ， 先 
择 “ 居 中 对 齐 ” 命 令 ， 让 插入 的 表格 居中 对 齐 ， 如 图 4-27 所 示 。 


S am——— —— —z———— J—— 5; 
EF 表格 awe | mors er ~| 填充 中) jwEOU erir | OX — v 
= | wo | 间距 G)D ”| 边框 (8)j0 | 


wee maees[ o 
ia 
4-27 设置 “居中 对 齐 ” 
(8) 把 光标 移 至 创建 表格 第 2 行 第 1 列 中 ， 在 “属性 ”面板 中 设置 高 上 度 为 456 像素 、 宽 
BE 179 像素 。 设 置 高 度 和 宽度 时 ， 根 据 背 景 图 像 而 定 ， 从 “背景 ”中 选择 该 站 点 中 images 
文件 夹 中 的 02.gif 文件 ， 得 到 的 效果 如 图 4-28 所 示 。 


T Ca chelst docs menter Vindex. shs* 

E LG oes 
Y e - - db 

i. Done ae JE 而 一 

| po^ ag [efo] 

















mem : ' ER XI 
(Qe? GANLO Grot [VIO or 901 x 646v 63 KE / 2 EP Unicode OTEO) 


4-28 插入 图 上 厂 的 效果 图 


(9) 在 表格 的 第 2 行 第 2 列 和 第 3 列 中 ， 分 别 插 入 同 站 点 images 文件 夹 中 的 图 片 03.gif 
和 04.gif， 完 成 网 页 的 结构 搭建 ， 如 图 4-29 所 示 。 
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图 4-29 完成 的 网 页 背景 效果 图 


(10) 单 击 第 2 行 第 1 列 单元 格 ， 然 后 再 单 击 “ 文 档 ” 窗 口上 的 d£ H 在 <td> 和 
</td> 之 间 加 入 valign="top" (表格 文学 和 图 片 的 相对 捍 放 位 置 ， 可 选 值 为 top、 middle、 
bottom) 的 命令 ， 表 示 让 鼠标 能 够 自动 地 贴 至 该 单元 格 的 最 顶部， 设置 如 图 4-30 所 示 。 
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图 4-30 ”设置 单元 格 的 对 齐 方式 为 最 顶部 


注意 : 

文档 工具 栏 中 包含 按钮 和 弹出 的 菜单 ， 提 供 各 种 文档 “窗口 视图 ”( 如 “设计 ”、“ 拆 
分 ”和 “代码 ”视图 )、 各 种 查看 选项 和 一 些 常 用 操作 ( 如 在 浏览 器 中 预览 )。 

对 选项 说 明 如 下 。 

“代码 ”: 显示 代码 视图 ， 仅 在 “文档 ”窗口 中 显示 代码 视图 。 

“ 拆 分 ”: 显示 代码 视图 和 设计 视图 ， 在 “文档 ”窗口 的 一 部 分 中 显示 代码 视图 ， 而 在 另 
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一 部 分 中 显示 设计 视图 。 
“设计 ”: 显示 设计 视图 ， 仅 在 “文档 ”窗口 中 显示 设计 视图 。 
“标题 ?>: 允许 为 文档 输入 一 个 标题 ， 它 将 显示 在 浏览 器 的 标题 栏 中 。 
“没有 浏览 器 /检查 错误 ”: 可 以 检查 跨 浏 览 器 兼容 性 。 
“文件 管理 ”: 显示 文件 管理 弹出 菜单 。 
“在 浏览 器 中 预览 /调试 ?: 在 浏览 器 中 预览 或 调试 文档 ， 从 弹出 菜单 中 选择 一 个 浏览 器 。 
“刷新 设计 视图 F5”: 当 在 代码 视图 中 进行 更 改 后 刷新 文档 的 设计 视图 。 
“视图 选项 ”: 允许 为 代码 视图 和 设计 视图 设置 选项 ， 如 “标尺 ”、“ 网 格 ”、“ 文 件 头 ”内 
(4D) 单 击 “文档 ”窗口 上 的 | 设计 按钮， 返回 文 档 窗口 的 “设计 ”窗口 模式 ， 在 刚 创 
建 表格 的 单元 格 中 ， 执 行 亲 单 “ 插 入 记录 ”一 “表单 ”一 “表单 ”命令 ， 如 图 4-31 所 示 ， 
插入 一 个 表单 。 
Dw | wn -[[8— Oow CEES 


AEG) 编辑 (EF) EO 修改 0 AO — r$ (C) 站 点 (3) ”窗口 (四 H) 

TE G)... Ctrl+E C: \Apachethtdocs\member\indez. php -— 
ü TE = n CtrltAlt*I 
: fu | 拆 分 设计 | KH ENSOHE (6) b 
i 地 址 : ; 媒体 D " 
LN í WEE M)... 
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y 











indez. php* X 




















若 要 在 该 页 面 上 使 用 动态 数据 : 
Y d. 请 涯 该 立 件 创建 一 个 站 点 。 
v 2. 选择 一 种 立 挡 类 型 。 
3. ED BOR SS SE. 
4. ENS H 按钮 并 选择 记 
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服务 器 端 包括 (E) 单 选 按钮 R) 




























































注释 C) 选择 ( 列表 /菜单 》(S) 
IE EGG mr. n 次 件 域 FF) - 
:| 会 员 登 录 Elit CD) 特别 
| 模板 对 象 ) | er 
最 近 的 代 玛 片断 R) » P4 : 
. | 单 选 按钮 姐 (G) 
二 E 
jQuery Mobile > WERE O) 
OO InContext Editing(I) 上 FRE (8) 
: ERAGE 数据 对 象 I) 上 FEE) 
Fre dia Ld "| spry 验证 文本 域 @) > 
<body> <table> Cr? t7] 自 定 六 收藏 夹 Qu)... Spry 验证 文本 区 域 0 Unicode (UTF-8) 
尾 性 | 获 职 更 多 对 象 (6)... Spry WES EHE C) "三 
om) wm — — SIR srao Bol 
HEO Spry aE 
i css ID(I) | 无 v Spry 验证 确认 (0) (G) 





























=F] 单元 格 KFR y OD 179 PRT] Spry 验证 单 选 掖 钮 组 1 
[E ojt  £&B mx v 高 om «x 4280 [] 


























图 4-31 执行 “表单 ”命令 


C120 将 眼 标 放置 在 该 表单 中 ， 执 行 采 单 “ 插 入 记录 ”一 “表格 ”命令 ， 打开 “表格 ” 
对 话 框 ， 在 “ 行 数 ”文本 框 中 输入 5， 在 “ 列 数 ”文本 框 中 输入 2。 在 “表格 宽度 ”文本 框 
中 输入 179 像素 ， 在 该 表单 中 插入 5$ 行 2 列 的 表格 。 单 击 并 拖 动 鼠标 ， 分 别 选择 第 1 行 、 第 
2 行 和 第 5 行 表 格 ， 并 分 别 在 “属性 ”和 面板 中 单 击 使 用 “合并 所 选单 元 格 ， 使 用 跨度 ”按钮 
回 ， 将 这 几 行 表格 进行 合并 。 然 后 在 表格 的 第 1 行 输 入 “会 员 登 录 ”4 个 字 ， 在 第 2 行 第 1 
列 中 输入 文字 说 明 “ 用 户 名 ” 在 第 2 行 第 2 列 中 执行 菜单 “插入 记录 ”一 “表单 ”一 “、》 
本 域 ” 命 令 ， 插 入 一 个 单行 文本 域 表 单 对 象 ， 并 定义 文本 域名 为 “username”,“ 文 本 域 ” 属 
性 设置 及 此 时 的 效果 如 图 4-32a、b 所 示 。 

说 明 : 设置 文本 域 的 属性 说 明 如 下 。 

1) 在 “文本 域 ”文本 框 中 ， 为 “文本 域 ”指定 一 个 名 称 。 每 个 “文本 域 ”都 必须 有 一 
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个 唯一 名 称 。 表 单 对 象 名 称 不 能 包含 空格 或 特殊 字符 ， 可 以 任意 组 合 字 母 、 数 字 、 mE 








EZ O( )。 请 注意 ， 为 “文本 域 ”指定 的 标签 将 存储 该 域 的 值 (输入 的 数据 ) 的 变 ， 这 
是 发 送 给 服务 器 进行 处 理 的 值 。 
ne e 
[7 br TAPER) 2 | 类 型 OTe OsTmM OSBP) SO X vw 
最 多 字符 数 | | WED | | 多 
口 禁 用 0) 
ORR R 
a) 
IEEE: 
rr l 
(BREST s 
E ro cb UL Suet Ree p. d 
1 
a eS : 
b) 


4-32 输入 “用 户 名 ”和 搬入 “文本 域 ” 的 设置 


2 )“ 字 符 宽 度 ” 设 置 域 中 最 多 可 显示 的 字符 数 。 用 “最 多 字符 数 ” 指 定 在 域 中 可 We 
最 多 字符 数 ， 如 果 保 留 为 空白 ， 则 输入 不 受 限 制 。“ 字 符 宽度 ”可 以 小 于 “最 多 字符 数 ”"， 但 
大 于 “最 多 字符 数 ” 的 输入 则 不 被 显示 。 

3 )“ 类 型 ”用 于 指定 文本 域 是 “单行 "、“ 多 行 ”还 是 “密码 ” 域 。 单 行文 本 域 只 能 显 
_ 行 文字， 多 行 则 可 以 输入 多 行文 字 ， 达 到 字 we 密码 。 

4 )“ 初 始 值 ”指定 在 首次 载 入 表单 时 ， 域 中 显示 的 值 。 例 如 ， 通 过 包含 说 明 或 示例 值 ， 
可 以 指示 用 户 在 域 中 输入 信息 。 

5) “类 ”可 以 将 CSS 规则 应 用 于 对 象 。 


(13) 在 第 3 行 第 1 列表 格 中 输入 文字 说 明 “ 密 码 ” 在 第 3 行 表格 的 第 2 列 中 执行 菜单 
“插入 记录 ”一 “表单 ”一 “文本 域 ” 命 令 ， 插 入 密码 文本 域 表 单 对 象 ， 定 义 “文本 域 ” 名 
为 password。“ 文 本 域 ” 属性 设置 及 此 时 | 的 效果 如 图 4-33a. b 所 示 。 








属性 
文本 域 字符 宽度 m) |12 | 类 型 OTe Osam —GOZzec 类 加 | 无 v 
最 多 字符 数 | | USD [19 
OSAD) 
[.] Ri () 
a) 
会 员 登 录 | 


4-33 ”密码 “文本 域 ” 的 设置 
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(14) 选择 第 4 行 单元 格 ， 执 行 染 单 “ 插 入 记录 ”一 “表单 ”一 “按钮 ”命令 两 次 ， 插 
入 两 个 按钮 ， 并 分 别 在 “属性 ”和 面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ” 选 
项 ， 一 个 为 “ 重 设 表单 ”选项 。“ 属 性 ”的 设置 如 图 4-34a、b Br. 








尾 性 
按钮 名 称 Ev) 动作 ORTER GG) OTM 类 GO 无 M 
OFRES M) 
a) 
尾 性 
| 按钮 名 称 值 v) 动作 〇 ) 提交 表单 G) Ox BOX v 
全 重 设 表单 M 
b) 


4-34 设置 按钮 名 称 


(150 在 第 5 行 输入 “注册 痢 用 户 ” 文 本 ， 并 设置 一 个 转 到 用 户 注册 页 面 registerphp 的 
链接 对 象 ， 以 方便 用 户 注册 ， 和 输入 的 效果 如 图 4-35a. b 所 示 。 


属性 
SXO x ~v 类 ETFI DIN 
Bs | mo) io) Joo mol v 

国 Ar KFORU ë 0 X0 7 | 不 换行 0) 口 WREAR&O.J —— 页 面 属性 .. 
— (jc 重 直 中) 黑人 vaw c) 标题 @) 口 





register. php 








4-35 ”建立 链接 








(16) 如 末 已 经 注册 的 用 户 瑟 记 了 密码 ， 还 布 望 以 其 他 方式 能 够 重新 获得 密码 ， 可 以 在 
表格 的 第 4 列 中 输入 “ 找 回 密码 ”文本 ， 并 设置 一 个 转 到 密码 合 询 页 面 lostpassword.php 的 
链接 对 象 ， 方 便 用 户 取 回 密 码 ， 如 图 4-36a、b 所 示 。 

(17) 表单 编辑 完成 后 ， 下 面 来 编辑 该 网 页 的 动态 内 容 ， 以 便 用 户 可 以 通过 该 网 页 中 
表单 的 提 区 实现 登录 功能 。 打 开 “ 服 务 右 行为 ”面板 ， 单 击 该 面板 上 按钮 四， 执行 全 单 
“用 户 身 份 验证 ”一 “登录 用 户 ” 命 令 ， 如 图 4-37 所 示 ， 向 该 网 页 添加 “登录 用 户 ” 的 服 
PARIT N o 

(18) 此 时 打开 “登录 用 户 ” 对 话 杠 ， 各 项 参数 设置 如 网 4-38 所 示 。 
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4-37 添加 “登录 用 户 ” 服 务 需 行为 
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MO BASH LA. : 


MPRA: 
sug. 


mpi, HA 

[] 转 到 前 一 个 WRLT 加 果 它 存在 》 
DRERAR HA 
基于 以 下 项 限制 访问 : © ”用 户 名 和 密码 

O 用 户 名 。 密 码 和 访问 级 别 

SEHRERRUB: 








图 4-38 “登录 用 户 ” 对 话 框 


该 对 话 框 中 各 项 设置 的 作用 如 下 。 

1) 从 “从 表单 获取 输入 ”下 拉 列 表 框 中 ， 选 择 该 服务 器 行为 使 用 网 页 中 的 forml 对 
销 ， 设 定 访 用户 登录 服务 占 行 为 的 用 户 数 据 来 源 为 表单 对 象 中 访问 者 填写 的 内 容 。 

2) 从 “用 户 名 字段 ”下 拉 列 表 框 中 ， 选 择 文 本 域 username 对 象 ， 设 定 该 用 户 登 录 服 务 
器 行为 的 用 户 名 数据 来 源 为 表单 的 username 文本 域 中 访问 者 输入 的 内 容 。 

3) 从 “密码 字段 ”下 拉 列 表 框 中 ， 选 择 文 本 域 password 对 象 ， 设 定 该 用 户 登录 服务 器 
行为 的 密码 数据 来 源 为 表单 的 password 文本 域 中 访问 者 输入 的 内 容 。 

4) 从 “使 用 连接 验证 ”下 拉 列 表 框 中 ， 选 择 用 户 登 录 服 务 器 行为 使 用 的 数据 源 连 接 对 
2 7j my member. 

50 从 “表格 ”下 拉 列 表 框 中 ， 选 择 该 用 户 登 录 服 务 器 行为 使 用 到 的 数据 库 表 对 象 为 
member。 

60 从 “用 户 名 列 ” 下 拉 列 表 杠 中， 选择 表 member 存储 用 户 名 的 字段 为 username。 

7) 从 “密码 列 ” 下 拉 列 表 杠 中， 选择 表 member 存储 用 户 密 码 的 字段 为 password. 

8) 在 “如 有 果 登 录 成功 ， 转 到 ”文本 框 中 输入 登录 成 功 后 ， 转 问 welcome.php W H. 

9) 在 “如 果 登 录 失 败 ， 转 到 ”文本 框 中 输入 登录 失败 后 ， 转 癌 loginfail.php 页 面 。 

100 选择 “基于 以 下 项 限制 访问 ”后 面 的 “用 户 名 和 密码 ” 单 选 按钮 ， 设 定 后 面 将 根据 
用 户 的 用 户 名 、 密 人 码 共同 决定 其 访问 网 页 的 权限 。 

(190 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 在 “ 服 
务 器 行为 ”面板 中 就 增加 了 一 个 “登录 用 户 ” 行 为 ， 如 图 4-39 所 示 。 

(200 表单 对 象 对 应 的 “属性 ”面板 的 动作 属性 值 如 图 4-40 所 示 ， 为 <?php echo $login 
FormAction; ?>。 它 的 作用 吏 是 实现 用 户 登 录 功 能 ， 这 是 一 个 Dreamweaver 上 自动 生成 的 动作 
代码 。 

(21) 执行 染 单 “文件 ”一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 ， 完 成 网 站 的 首 
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4-39 “服务 占 行 为 ”和 面板 


<?php echo $loginFormAction; ?> (oO 目标 (7T) | 图 XO 无 E 
mrs vj «nen exci 








4-40 表单 对 象 对 应 的 “属性 ”面板 


O 登录 成 功 和 失败 


当 用 户 输 入 的 登录 信息 不 正确 时 ， 束 会 转 到 loginfailphp 页 面 ， 显 示 登 录 失 败 的 信息 。 











如 果 用 户 输入 的 登录 信息 正确 ， 就 会 转 到 welcome.php 页 面 。 下 面 首先 来 制作 loginfail.php 
页 耐 ， 评 细 制 作 步 又 如 下 。 

(1) 执行 洒 单 “文件 ”一 “ 独 建 ”命令 ， 在 网 站 根 目录 下 刹 建 一 个 名 为 loginfail.php 的 
网 页 并 保存 。 

(2) 登录 失败 页 面 设计 如 图 4-41 所 示 。 在 “文档 ”窗口 中 选中 “这 里 ”文本 ， 在 其 对 
应 的 “属性 ”面板 上 的 “链接 ”文本 框 中 输入 index.php， 将 其 设置 为 指向 index.php 页 面 的 
链接 。 
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请 单 击 这 里 重新 登录 





4-41 登录 失败 页 面 loginfail.php 


(3) 执行 洒 蛙 “文件 ”一 “保存 ”命令 ， 完 成 loginfail.php 页 面 的 创建 。 

接 下 来 制作 welcome.php 页 耐 ， 详 细 制 作 的 步 又 如 下 。 

(1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 welcome.php 的 
网 页 并 保存 。 
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(2) 用 类 似 制作 登录 失败 页 面 的 方法 制作 登录 成 功 页 面 的 静态 部 分 ， 如 图 4-42 Dr. 
G) 执行 沫 单 “ 窗 口 ” 一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 [村 按钮 ， 
在 弹出 的 某 音 中， 选择 “阶段 变量 ”选项 ， 为 网 页 中 定义 一 个 阶段 变量 ， 如 图 4-43 Br. 





_ 数据 库 | sE | 服务 器 行为 | -三 
CH 一 文档 类 型 : ne 
记录 集 ( 查询 ) 
表单 变量 
EEUU URL 变量 em 
登录 成 功 4 | 阶段 变量 
PO Cookie 变量 
Mee : 服务 器 变量 
- E TARE 
EMTA TE Spry 数据 集 
TESEHREFESIFH P: 获 职 数据 源 ... 
图 4-42 ”登录 成 功 页 面 的 效果 图 图 4-43 ”添加 阶段 变量 


重点 说 明 : 

绑 定 面板 中 “阶段 变量 ”命令 经 第 使 用 ， 有 具体 的 功能 说 明 如 下 。 

阶段 变量 提供 了 一 种 对 象 ， 通 过 这 种 对 和 象 ， 用 户 信 息 得 以 存储 ， 并 使 该 信息 在 用 己 访 问 
的 持续 时 间 中 对 应 用 程序 的 所 有 页 都 可 用 。 阶 段 变 量 还 可 以 提供 一 种 超时 形式 的 安全 对 象 ， 
这 种 对 象 在 用 户 账 户 长 时 间 不 活动 的 情况 下 ， 终 止 该 用 户 的 会 话 。 如 果 用 户 忘记 从 Web 站 
点 注销 ， 这 种 对 象 还 会 释放 服务 器 内 存 和 处 理 资 源 。 





(4) 打开 “阶段 变量 ”对 话 框 ， 在 “名 称 ” 文 本 框 中 输入 “阶段 变量 ”的 名 称 MM 
username， 如 图 4-44 所 示 。 

(5) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “人 确定” 按钮， 在 “文档 ”窗口 中 通过 拖 动 腿 标 选 
择 “XXXXXX” 文 本 ， 然 后 在 “ 绑 定 ”面板 中 选择 MM_username 变量 ， 再 单 击 “ 绑 定 ” 面 
板 底 部 的 “插入 ”按钮 ， 将 其 插入 到 该 “文档 ”窗口 中 设 定 的 位 置 。 插 入 完毕 ， 可 以 看 到 
4XXXXXX" XN li (Session. MM, username] EA AH, un] 4-45 所 示 。 这 样 ， 就 完成 了 
这 个 显示 登录 用 户 名 “阶段 变量 ”的 添加 工作 。 





Bip 


mW. Wiusemme | | L8 


REB 





图 4-44 “阶段 变量 ”对 话 框 图 4-45 插入 后 的 效果 
重点 提示 : 设计 阶段 交 量 的 目的 ， 是 在 用 户 登 录 成 功 后 ， 登 录 界 面 中 可 以 直接 显示 用 户 
的 名 字 ， 使 网 页 更 有 亲切 感 。 


(6) 在 “文档 ”窗口 中 拖 动 鼠 标 选 中 “注销 你 的 用 户 ” 文 本 。 执 行 菜单 “窗口 ”一 “ 服 
务 器 行为 ”一 “用 户 身份 验证 ”一 “注销 用 户 ” 命 令 ， 为 所 选中 的 文本 添加 一 个 “注销 用 
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户 ” 的 服务 器 行为 ， 如 网 4-46 所 示 。 
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4-46 “注销 用 户 ” 命 令 


CI) 打开 “注销 用 户 ” 对 话 框 ， 在 该 对 话 框 中 进行 如 下 设置 。 

1)“ 在 以 下 情况 下 注销 ”用 于 设置 注销 时 机 ， 本 例 选 择 “ 单 击 链接 ” 单 选 按钮 ， 并 在 右 
边 的 下 拉 列 表 框 中 选择 “所 选 范围 : 注销 你 的 用 户 ” 这 样 当 用 户 在 页 面 中 单 击 “ 注 销 你 的 
HP T BESEDAATTERS BRE. 

2)“ 在 完成 后 ， 转 到 ”文本 框 用 于 注销 后 显示 的 页 面 ， 本 例 在 右 侧 文本 框 中 输入 
logootphp， 表 示 注 销 后 转 到 logootphp 页 面 ， 完 成 后 的 设置 如 图 4-47 所 示 。 











在 以 下 情况 下 注销 : © 单 击 链接 ;| 所 选 范围 ; ”注销 你 的 用 户 ” ~] 
O 页 面 载 入 
在 完成 后 ， 转 到 : logoot.php | 

















4-47 ”设置 完成 后 的 “注销 用 户 ” 对 话 杠 





(8) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对话 框 ， 返 回 到 “文档 ”窗口 。 在 “服务 
器 行为 ”面板 中 增加 了 一 个 “注销 用 户 ” 行 为 ， 同 时 可 以 看 到 “注销 用 户 ” 链 接 文本 对 应 的 
“属性 ”面板 中 的 “链接 ”属性 值 为 <?php echo $logoutAction ?>， 它 是 Dreamweaver 目 动 生 
成 的 动作 对 和 象 。 

(9) logoot.php 的 页 面 设计 比较 简单 ， 不 做 详细 说 明 ， 在 页 面 中 的 “这 里 ”处 指定 一 个 
链接 到 首页 index.php 就 可 以 了 ， 效 果 如 图 4-48 PZR. 














T5. C: M pachehtdocs'memberVlogoot. php (XHTML) -0X 


BERAE? 您 已 实 全 退出 


重新 登录 倩 单 击 习 里 。 





[kd Q 100 — 4518 x 131v 1 EK / 1 dh Unicode WIF-8) | — -: 
图 4-48 注销 用 户 页 面 设计 效 末 图 
(100. 执行 菜单 “文件 ”一 “保存 ”命令 ， 将 该 文档 你 存 到 本 地 站 所 中 。 编 辑 工作 完成 


后 ， 就 可 以 测试 该 用 户 登 录 系 统 的 执行 情况 了 。 文 档 中 的 “修改 您 的 注册 资料 ”链接 到 
userupdate.php 页 面 ， 此 页 面 将 在 后 面 的 修改 革 节 中 进行 介绍 。 


3 登录 功能 的 测试 


制作 好 一 个 系统 后 ， 需 要 测试 无 误 ， 才 能 上 传 到 服务 器 使 用 。 下 面 加 对 登录 系统 进行 如 
下 测试 。 

(1) 打开 下 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/， 打 开 index.php 页 面 ， 如 
图 4-49 所 示 。 








A PHP 用 户 管理 系统 一 Nicroso ft Internet Explorer DE) 
AEG) 编辑 人 ) ”查看 0) KAO IAT) #5 H) 


QmE-O-[9idt( Pst ux 6 四 - aB 
地 址 0) E] http: //127. 0. 0. 1/menber/] Qera SE Qus 加 


N N Ds 


foe Lo «s 
A » > joue Nh 


会 员 登 录 联系 我 们 














^ 





特别 推荐 





产品 党 明 : 三 星 智能 手机 , 100 万 像素 , 支持 呀 3、 吧 4 
和 蓝牙 技术 .手写 功能 , 外 观 美 等 特点 。 











联想 手提 电脑 


本 书 是 一 本 关于 动态 网 站 开发 的 技术 图 书 ,专门 汶 : 
初次 接 解 动态 网 站 开发 的 读者 而 写作 。 ; 


"x | 
APZ E i | 
* : REI 忧 惠 价 : Y 2480 
| 全 see " a 
:注册 新 用 户 找 回 密码 =P 

t 


忧 囊 价 : Y oo 
会 员 价 : Y23.8 





4-49 打开 的 网 站 首页 


(2) 在 “用 户 名 ”和 “密码 ”文本 框 中 分 别 输 入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
ox" TR. 

(3) 如 果 在 第 2 步 中 填写 的 登录 信息 是 错误 的 ， 或 者 根本 就 没有 输入 ， 则 浏览 器 就 会 转 
到 登录 失败 页 面 loginfailphp， 显 示 登 录 失 败 信 息 ， 如 图 4-50 所 示 。 
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联系 我 们 











| E EN 





| Bn 


: 登录 失败 ,请 检查 你 所 填写 的 用 户 名 和 密码 是 否 正 确 





请 单 击 这 里 重新 登录 4 | 
:联想 手提 电脑 
sis (UE ; p 





1. 选 购 产 品 
2 .确定 订购 
3. 网 上 付款 
4.385188. 





B Internet 


4-50 登录 失败 页 面 loginfail.php 效果 





(4) 如 宁 输 入 的 用 户 名 和 密码 都 正确 ， 则 显示 登录 成 功 页 面 。 这 里 输入 的 是 前 面 数 据 库 
设置 的 用 户 design， 登 录 成 功 后 的 页 面 如 图 4-51 所 示 ， 其 中 显示 了 用 户 名 design. 


E zc iu Nicrosoft Intermet Explorer 
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4-51 登录 成 功 页 面 welcome.php 效果 





(5) 如 果 想 注销 用 户 ， 只 需要 单 击 “ 注 销 你 的 用 户 ” 超 链接 即 可 。 注 销 用 户 后 ， 浏 览 器 
束 会 转 到 页 面 logootphp， 然 后 单 击 “ 这 里 ” 回 到 首页 ， 如 图 4-52 所 示 。 全 此 ， 登 录 功 能 束 
测试 完成 。 









PHP 


J 注销 用 户 - Nicrosoft Internet Explorer mB) 
TFP AED 查看 收藏 以) IR() #5 w) Ed 


QAE- O- DBOR: wx o e- RBL 
地 址 四 ) | 四 http://127.0.0. 1/menber/1ogo0t.ph V| EJ PA HHE Q snett E 
BUTADA? 您 已 安全 退出 
重新 登录 请 单 击 这 里 。 


(MD Internet 





图 4-52 注销 用 户 页 面 效 果 





蕊 必用 户 注 册 模块 的 设计 


用 户 登 录 系 统 是 为 数据 库 中 已 有 的 老 用 户 登 录用 的 ， 一 个 用 户 管理 系统 还 应 该 提供 新 用 
户 注册 用 的 页 面 。 对 于 新 用 户 来 说 ， 通 过 单 击 index.php 页 面 上 的 “注册 新 用 户 ” 超 链接 ， 
进入 到 名 为 register.php 的 页 面 ， 在 该 页 面 中 实现 新 用 户 注册 功能 。 


ien HAARA 


register.php 页 面 主要 实现 用 户 注册 的 功能 ， 用 户 注册 的 操作 就 是 向 member.mdb 数据 库 
的 member 表 中 添加 记录 的 操作 ， 完 成 的 页 面 如 图 4-53 所 示 。 


T C: XApacheXhtdocs*memberkregister. php MISC 








PL." union 


D 


poi 心 "s ED 联系 我 们 

















2. 确 定 订 购 
3. 网 上 付款 








R] Q 1008  » T49 x 511v 65 K / 2 ^ Unicode QF-8) 


图 4-53 用户 注册 页 面 样式 
C) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 日 录 下 新 建 一 个 名 为 register.php 的 网 











QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





第 4 章 GCGIELPEULEAÀ 





页 并 你 存 。 

(2) 在 Dreamweaver 中 使 用 制作 静态 网 页 的 工具 ， 完 成 如 图 4-54a、b 所 示 的 静态 部 
分 ， 这 里 要 说 明 的 是 ， 注 册 时 需要 加 入 一 个 “隐藏 域 ” 并 命名 为 authority, Vx E SUA TH 
0， 即 所 有 的 用 户 注册 的 时 候 默 认 是 一 般 访问 用 户 。 
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图 4-54  register.php 页 面 静 态 设 计 


重点 提示 : 在 为 表单 中 的 文本 域 对 象 命名 时 ， 由 于 表单 对 象 中 的 内 容 将 被 添加 到 
member 表 中 ， 因 此 设置 表单 对 和 象 中 的 文本 域名 与 数据 库 中 的 相应 字段 名 相同 ， 这 样 做 的 目 
的 是 当 该 表单 中 的 内 容 添 加 到 member 表 中 时 可 以 自动 配对 。 文 本 “密码 验证 ”对 应 的 文本 
框 命名 为 password1。 隐藏 域 是 用 来 收集 或 发 送信 息 的 不 可 见 元 素 ， 对 于 网 页 的 访问 者 来 
说 ， 隐 藏 域 是 看 不 见 的 。 当 表单 被 提交 时 ， 隐 藏 域 就 会 将 信息 用 设置 时 定义 的 名 称 和 值 发 送 
到 服务 器 上 。 





G) 还 需要 设置 一 个 验证 表单 的 动作 ， 用 来 检查 访问 者 在 表单 中 填写 的 内 容 是 售 满 足 数 
据 库 中 表 member 中 字段 的 要 求 。 在 将 用 户 盾 写 的 注册 资料 提交 到 服务 器 之 前 ， 首 先 对 用 户 
填写 的 资料 进行 验证 。 如 果 有 不 符合 要 求 的 信息 ， 可 以 癌 访 问 者 显示 错误 的 原因 ， 并 让 访问 
者 重新 输入 。 

(4) 执行 染 单 “窗口 ”一 “行为 ”命令 ， 则 会 打开 “行为 ”面板 。 单 击 “ 行 为 ”面板 
中 的 [ 国 按 钮 ， 从 打开 的 行为 列表 中 选择 “检查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 如 
图 4-55 所 示 。 

本 例 中 ， 设 置 username 文本 域 、password 文本 域 、password1 文本 域 、answer 文本 域 、 
truename 文本 域 、address 文本 域 为 “ 值 : 必需 的 和 “可 接受 : 任何 东西 ” 即 这 儿 个 文本 域 
必须 填写 ， 内 容 不 限 ， 但 不 能 为 至; tel 文本 域 和 qq 文本 域 设 置 的 验证 条 件 为 “ 值 : 必需 
的 “可 接受 数字 ” 表示 这 2 个 文本 域 必须 填写 数字 ， 不 能 为 空 ，e-mail 文本 域 的 验证 
条 件 为 “ 值 : 必需 的 入 “可 接受 : 电子 邮件 ” 表示 该 文本 域 必 须 填写 电子 邮件 地 址 ， 且 不 


bB oL, 2x 
能 为 容 。 
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fü: 必需 的 


可 接受 名 ”性 何 末 西 O m" 
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图 4-55 设置 “检查 表单 ”对 话 框 


(50 设置 完成 后 ， 单 击 “确定 ”按钮 ， 完 成 对 检 奉 表单 的 设置 。 
(6 在 “文档 ”窗口 中 单 击 工具 栏 上 的 [到 | 扩 钮 ， 转 到 代码 编辑 窗口 ， 然 后 在 验证 表 
单 动 作 的 源 代 人 码 中 修改 如 下 的 代码 ， 主 要 是 实现 中 文 汉化 的 功能 。 
<script type= text/Javascript"» 
/宣告 脚本 语言 为 JavaScript 
function MM validateForm() { //v4.0 
if (document. getElementById){ 








var 1,p,q,nm,test,num,min,max,errors=",args=MM_validateForm.arguments; 
for (120; 1<(args.length-2); 1+=3) { testzargs[1-2]; val=document.getElementById(args[1]); 
if (val) { nm=val.name; if ((val=val.value)!="") { 
if (test.indexOf(isEmail')!=-1) { pzval.indexOf( (5; 
if (p«1 || p==(val.length-1)) errors+= '+nm+' £i; Z4 An"; 
/如 末 提 交 的 邮箱 地 址 表单 中 不 是 邮件 格式 ， 则 显示 为 “需要 和 输入” 
} else if (test!='R') ( num = parseFloat(val); 
if (isNaN(val)) errors+='- '+nm+' 需 要 输入 数字 .my 
/如 有 果 提 交 的 电话 表单 中 不 是 数字 ， 则 显示 为 “需要 输入 数字 ” 
if (test.indexOf('inRange?) != -1) { p=test.indexOf(':'); 
min-test.substring(8,p); max-test.substring(p4-1); 
if (num&min || max«num) errors+='- '+nm+' 震 要 输入 数字 '+min+' and '+max+'.\n'; 
// 如 下 提交 的 QQ 表单 中 不 是 数字 ， 则 显示 为 “需要 输入 数字 ” 
} } } else if (test.charAt(0) == RD errors += ~ '+nm+' is 需要 输入 .\n'; } 
// 如 果 提 交 的 地 址 表单 为 室 ， 则 显示 为 “需要 输入 ” 
} if (errors) alert( 注 册 时 出 现 如 下 错误 :n+errors); 
// 如 果 出 错 将 显示 “注册 时 出 现 如 下 错误 : 
document.MM returnValue = (errors == "); 


























jj 
</script> 
编辑 代码 完成 后 ， 单 击 工具 栏 上 的 | GE | 按钮， 返回 到 “文档 ”窗口 。 
此 时 ， 可 以 测试 一 下 执行 的 效果 ， 不 输入 相应 的 信息 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 则 会 打 
开 一 个 警告 框 ， 如 图 4-56 所 示 。 
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4-56 “提示 错误 ”对 话 杠 


(7) 在 该 网 页 中 添加 一 个 “插入 记录 ”的 服务 融 行为 。 执 行 菜 单 “ 和 窗口” 一 “服务 露 行 
H? 命令， 打开“ 服务 器 行为 ”面板 。 单 击 该 面板 上 | 蔬 | 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 插 
入 记录 ， 命令 ， 则 会 打开 “插入 记录 ”对 话 框 ， 如 图 4-57 Bp. 
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4-57 执行 “插入 记录 ”操作 


(8) 在 “插入 记录 ”对 话 框 中 进行 如 下 设置 。 

D 从 “连接 ”下 拉 列 表 框 中 选择 mymember 作为 数据 源 连 接 对 象 。 

2) 从 “插入 表格 ”下 拉 列 表 框 中 选择 member 作为 使 用 的 数据 库 表 对 象 。 

3) 在 “插入 后 ， 转 到 ”文本 框 中 ， 设 置 当 记录 成 功 添 加 到 表 member 后 转 到 regok.php 
网 页 。 

4) 在 对 话 框 下 半 部 分 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 member. 中 的 字段 一 一 对 应 
起 来 。 设 置 完成 后 该 对 话 框 如 图 4-58 所 示 。 
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提交 为 : 文本 v 
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图 4-58 设置 “插入 记录 ”对 话 框 


(9) 设置 完成 后 ， 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 此 时 的 设 
计 样 式 如 图 4-59 所 示 。 


Dw | $i v| [B — — O eue 
ABC) 编辑 (EF) 查看 (VY) HAT 修改 (人 M 格式 (0) 命令 ([C】 站 点 (3) 窗口 (内 ARH) 


register.php* Xx 
eii mymember. php — + — 立 档 类 型 : op 
| 代码 | 拆 分 | 设计 | | 实时 代码 pv A [实时 视图 Bm 0 O £RE- C. C 标题: SEEN ——— 
































|| 购物 流程 
ID à 密码 提示 问题 : 、 M eec 
1. 选 购 产 品 TORTE: : B members v 

















3. 网 上 付款 
4. 填 写 信 息 
5. 签收 产品 


lostpassword... 
regfail.php 
register.php 
regok.php 


showpassword... 


< 
<body> «table? Ctr? <td> <form> 


BED JE 
B css ID(I) 链接 CL) 
=E] 单元 格 KFORU ”| 宽 人 ) | 596| PRIO AMEG) | | #FEFErE | 页 面 属性 ... , 

一 oğ BOW — v Sw maw D] 文件 活动 已 完成 。 


showquestion... 


userupdate.php 





userupdateok... 





"t JS B18, e $ 


"ec pei 


welcome.php 











图 4-59 插入 记录 后 的 效果 图 


(100 用 户 名 是 用 户 登 录 的 身份 标记 ， 用 户 名 是 不 能 重复 的 ， 所 以 在 添加 记录 之 前 ,一 
定 要 先 在 数据 库 中 判断 该 用 户 名 是 否 已 存在 ， 如 有 果 存 在 ， 则 不 能 进行 注册 。 在 Dreamweaver 
中 提供 了 一 个 检查 新 用 户 名 的 服务 器 行为 ， 单 击 “ 服 务 器 行为 ”面板 上 四 按钮 ， 在 弹出 的 这 
单 中 ， 执 行 “ 用 户 映 份 验证 ”一 “检查 新 用 户 名 ”命令 ， 如 图 4-60 所 示 。 

此 时 ， 会 打开 一 个 “检查 新 用 户 名 ”对 话 框 ， (cod 话 框 中 进行 设置 。 

D Æ "HER" prt PISTE username 字段 。 























Dw | wm -|[8 — — Oor CEES 


文件 (F) 编辑 (E) 查看 (YW) 插入 (I) EAM EAO — r$ (C) 站 点 (3) gO HD 








Pet mymember. php 
代码 | 实时 代码 p [d 
i Qo C n Hu: £1e:///C|/Apache/htdocs/m 






































登录 用 户 
限制 对 页 的 访问 
| 购物 这 和 T ROREM 编辑 服务 器 行为. 








1 7 7 ; e| 新建 服务 器 行为 ，. 
1. 选 购 产 品 3 HE T EPRDPATSSIEOAI UE 获取 更 多 服 劳 器 行 洲 . - 
2. 确 定 订购 : : 
3. 网 上 付款 
4 .填写 信息 
5. 签 收 产品 














€ 
<body> <table> <tr> <td> <form> 


EE HRS userupdate. php 
格式 中】 无 Pc jE f£ r5 AA) IEEE! be 5 userupdateok... 
En CSS ID(I) | 无 he IO 目标 (6) o 705 welcome. php 
国 d KFG) 596| TATO FAME G) | .| [#FEFEFE 页 面 属性 ，. 
一 ma am 320| aw 文件 活动 已 完 成 。 






















































































4-60 “检查 新 用 户 名 ”命令 


2) 在 “如 果 已 存在 ， 则 转 到 ”文本 框 中 输入 regfail.php。 表 示 如 果 用 户 名 已 经 存在 ， 则 
转 到 regfail.php 负面， 显示 注册 失败 信息 ， 该 网 页 将 在 后 面 编辑 。 
设置 完成 后 的 对 话 框 显示 如 图 4-61 所 示 。 











TECHNO S 


用 户 名 字段 
DREFE RESI E 





4-61 设置 “检查 新 用 户 名 ”对 话 框 
(11) 设置 完成 后 ， 单 击 该 对 话 框 中 的 “确定 ”按钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ” 


窗口 。 在 “服务 器 行为 ”面板 中 ， 增 加 了 一 个 “检查 新 用 户 名 ”行为 ， 再 执行 染 单 “文件 ” 
一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 氮 中 ， 完 成 本 页 的 制作 。 














为 了 方便 用 户 登 录 ， 应 该 在 regok.php 页 面 中 设置 一 个 转 到 index.php. 页 面 的 文字 链接 ， 
以 方便 用 户 进 行 登 录 。 同 时 ， 为 了 方便 访问 者 重 靳 进行 注册 ， 则 应 该 在 regfailphp 页 和 设置 
一 个 转 到 registerphp 页 面 的 文子 链接 ， 以 方便 用 户 进行 重新 登录 。 本 节制 作 显示 注册 成 功 和 


失败 的 页 面 信息 。 
(1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 regok.php 的 网 
页 并 保存 。 















PHP 





(2) regok.php 页 面 如 网 4-62 所 示 。 制 作 比 较 简 单 ， 其 中 “这 里 ”文本 设置 为 指 问 
index.php 页 面 的 链接 。 


WC C:A&pachekhtdocsNmemberVregok. php (XHTML) 








特别 推荐 








v AEI MERHEM! 
:请 单 击 这 里 登录 ! 

i 联手 提 电 及 
pens 


1. 选 购 产品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 与 信息 





Eee € 
(RIS Q 100$ ~v|760 x 537v 83 K / 2# Unicode (UTF-8) 











4-62 注册 成 功 regok.php 负面 





(3) 如果 用 户 和 输入 的 注册 信息 不 正确 或 用 户 名 已 经 存在 ， 则 应 该 癌 用 户 显示 注册 失败 的 
信息 。 这 里 再 新 建 一 个 regfail.php 页 面 ， 访 页 面 的 设计 如 图 4-63 所 示 ， 其 中 “这 里 ”文本 
设置 为 指 问 register.php 页 面 的 链接 。 


a ona td php (XHTML) 


~ hb 
: 购物 中 心 | €mRUK 客户 留言 联系 我 们 = 
SI pm L— 7777777] 


| 产品 分 类 | EL 

















E 掌上 电脑 
:不 好 意思 ， 你 注册 的 用 户 名 已 经 被 注册 。 


:请 单 击 这 里 重新 注册 4 
É 联想 手提 电脑 





E 


1. 选 购 产品 
2. 确 定 订 购 


Alli 








2 | 3 
(RI Q 100%  v|T60 x 537v 83 K / 2# Unicode (UTF-8) — 


4-63 注册 失败 regfail.php 页 面 








QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 








用 户 管 理 系 统 开 发 


1E S 注册 功能 的 测试 


CT ls 
(1) 打开 IE 浏览 上 器， 在 地 址 栏 中 输入 http://127.0.0.1/member/register.php， 打 开 register. 
php 文件 ， 如 图 4-64 所 示 。 








| vic) amu) boo pma TAG) Whi 
G- o- Dourn reme ejna 
Liz CE l/nanbar/ragittar. pho -E amt wEJWM UN (ide E | 








uem *ruE 
RR Fi 认真 奸 写 注册 信 g 





osos 





4-64 打开 的 测试 页 面 


(2) 可 以 在 该 注册 页 面 中 输入 一 些 不 正确 的 信息 ， 如 漏 填 username. password 等 必需 字 
段 ， 或 填写 非法 的 E-mail 地址 ， 或 在 确认 密码 时 两 次 输入 的 密 但 不 一 致 ， 以 测试 网 页 中 验 
证 表单 动作 的 执行 情况 。 如 宋 填 写 的 信息 不 正确 ， 则 浏览 右 应 该 打开 警告 枉 ， 回 访问 者 显示 
错误 原因 。 如 图 4-65 所 示 是 一 个 警告 框 示 例 。 


PE T3 EU! iecrozefgft Internet 
adt i s , "nm 


WE 
Q oO-igie IR tR 6 2-2. 03 4 
ite a) A) http Wi 0 0 1/8 manber /ragi tar phy —ocih XR n "ow" qm [= ssi w | 


Ke 9: e | 
" e^ -— 7 gl Sod 





TUXIHE: 体 最 好 的 朋友 是 ? 
Eu pmET: 


EEs) 





图 4-65 ”出 错 提示 












PHP-*-MvySQL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





(3) 在 该 注册 页 和 面 中 注册 一 个 已 经 存在 的 用 户 名 ， 如 输入 design 测试 新 用 户 服务 器 行为 
的 执行 情况 ， 然 后 单 击 “确定 ”按钮 ， 此 时 由 于 用 户 名 已 经 存在 ， 浏 览 占 会 目 动 转 到 
regfail.php WH, WE 4-66 所 示 ， 告 诉 访问 者 该 用 户 名 已 经 人 存在。 此 时 ， 访 问 者 可 以 单 击 
“这 里 ”链接 文本 ， 返 回 registerphp HE, MEEI TNEI- 


UE Exe - 和 icroroft Internet Explorer 

xo) ec) Em mo 工具 dT) Woo 

Qgsme-O |i P*-*s «mx 6 23-202 

IEE D) E] bt //127.0.0 1/asaber/regfail Here quaer mns etin wo rw um* - EPS us Qn n 
- —— 


SHEER LG nso Ed 
vS aan 
olo| 


购物 中 心 5: 客户 留言 联系 我 们 
特别 推荐 
imam 
THRE.TrfOOescEWr. 
清单 击 信 时 重新 注 舱 ? 








图 4-66 注册 失败 页 面 显 示 


(4) 在 该 注册 页 耐 中 填写 正确 的 注册 信息 ， 单 击 “ 确 定 ” 按 钮 。 由 于 这 些 注册 资料 完全 
正确 ， 而 且 这 个 用 户 名 没有 重复 ， 浏 览 需 会 转 到 regok.php 页 面 ， 问 访问 者 显示 注册 成 功 的 
信息 ， 如 图 4-67 所 示 。 此 时 ， 访 问 者 可 以 单 击 “ 这 里 ”链接 文本 ， 转 到 index.php 页 面 ， 以 
便 进 行 登录 。 








3 "XX Microsoft Internet 71290737 
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4-67 注册 成 功 页 面 








在 MySQL 中 打开 用 户 数 据 库 文件 member， 查 看 其 中 的 member 表 对 象 的 内 容 。 此 时 可 
以 看 到 ， 在 该 表 的 最 后 已 创建 了 一 条 新 记录 ， 其 中 的 数据 就 是 刚刚 在 网 页 register.php 中 提交 
的 注册 用 户 的 信息 ， 如 图 4-68 所 示 。 






































Q9) Show SQL help 
dh Table Editor options 
Restore default size 








《 
| Grid view | FormView | Print Data 
Records fetched: 2/2 O LIMITO, 1000 














4-68 K member 中 添加 了 一 条 新 记录 


全 此， 基本 完成 了 用 户 管 理 系 统 中 注册 功能 的 开发 和 测试 。 在 制作 的 过 程 中 ， 可 以 根据 
制作 网 站 的 需要 适当 加 入 其 他 更 多 的 注册 文本 域 ， 也 可 以 给 需要 注册 的 文本 域名 称 部 分 添加 
星 号 〈*)， 提 醒 注 册 用 户 注意 。 


蕊 更 遇 ”资料 修改 模块 的 设计 


修改 注册 用 户 资料 的 过 程 就 是 往 用 户 数 据 表 中 更 新 记录 的 过 程 ， 本 市 重 扣 介绍 如 何在 用 
户 管理 系统 中 实现 用 户 资料 的 修改 功能 














O 修改 资料 页 面 














该 页 面 主要 是 把 用 户 所 有 资料 部 列 出 ， 通 过 “更 新 记录 ”命令 实现 资料 修改 的 功能 。 具 


体 的 制作 步骤 如 下 。 

(C1) 首先 制作 用 户 修改 资料 的 页 面 。 该 页 面 和 用 户 注册 页 面 的 结构 十 分 相似 ， 可 以 通过 
对 register.php 页 面 的 修改 来 快速 得 到 所 需要 的 记录 更 新 页 面 。 打 开 register.php 页 面 ， 执 行 菜 
单 “ 文 件 ” 一 “ 男 存 为 ”命令 ， 将 该 文档 为 存 为 userupdate.php， 在 第 一 行 加 入 如 下 代码 : 


<?php 
session_start(); 
?>// 让 session 环境 启动 


(2) 执行 菜单 “窗口 ”一 “服务 嚣 行为” 命令， 打开“ 服务 露 行为” 面板。 在 “服务 器 行 






























PHP+ QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





为 ”面板 中 删除 全 部 的 服务 器 行为 并 修改 其 相应 的 文学 ， 该 页 面 修改 完成 后 如 图 4-69 所 示 。 


局 C: \Apache\htdocs\member\userupdate. php (XHTML) -0X 


Pe Eh 


客户 留言 联系 我 人 













à " 











NN 


NSvvvvvvvvvvvvvvvvvvvsv 








|| 购物 流程 


1. 选 购 产 品 


TSS ASSSSSSSASSSASASSASSSASSSASAT 
PE TT TFET 


SY assssssa vv 





2. 确 定 订购 1 E 

3. 网 上 付款 : 

E 2 v 
< TIT | > 
<body> (k]éy Q [00%  .|T49 x 511» 66 K / 2 19 Unicode (UTF-8) - 








图 4-69  userupdate.php 静态 页 面 


(3) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 |[ 册 | 按钮 ， 
在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 选 项 ， 则 会 打开 “记录 和 集 ” 对 话 框 。 

在 该 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 upuser 作为 该 “记录 集 ” 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 选择 “user 数据 源 ” 连 接 对 和 象 为 mymember。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 和 象 为 member. 

4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

50 在 “ 饶 选 ” 栏 中 设置 记录 集 过 滤 的 条 件 为 UserName= 阶 段 变 量 / MM Username. 

完成 后 的 设置 如 图 4-70 所 示 。 























e. 
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图 4-70 设置 “记录 和 集 ” 对 话 框 
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(4) 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 完 成 记录 集 的 绑 定 。 
(5) 完成 记录 集 的 绑 定 后 ， 将 upuser 记录 集中 的 字段 绑 定 到 页 面 中 相应 的 位 置 ， 注 意 插 
入 一 个 隐藏 域 为 ID， 议 置 在 用 户 名 字段 的 后 面 ， 如 图 4-71 所 示 。 














E] C: N\Apache\htdocs\member\userupdate. php (XHTML) * -0X 


EAD nymenber. php TY 
Y ^ 


| Re I 


== 


购物 中 心 en ouy ZPE 联系 我 们 
RRPVEBRONINE 














^ 
iet 上 学 的 学 校 名 叫 ” 
er. r 





< > 
ible? <tr> <td> <form> <table> <tr> <td. .. > label>lKinput#ID |k |$) Q 100€ v749 x 487v T2 K / 2 fb Unicode (UTF-8) 
图 4-71 绑 定 动态 内 容 后 的 userupdate.php 页 面 


(6) 对 于 网 页 中 的 单 选 按钮 组 sex 对 象 ， 绑 定 动态 数据 可 以 按照 如 下 方法 : 单 击 “ 服 务 
器 行为 ”面板 上 | 直接 钮 ， 在 弹出 的 菜单 中 ， 执 行 “动态 表单 元 素 ” 一 “动态 单 选 按钮 ” 命 
令 ， 设 置 动态 单 选 按钮 组 对 象 。 打 开 “ 动 态 单 选 按钮 组 ”对 话 框 ， 从 “动态 单 选 按钮 组 ” 下 
diia 选择 forml 表单 中 的 单 选 按钮 组 sex. Hh; XEHUBARIC LAE H 

E E 
ec dene 动态 绑 定 ， 设 置 完成 后 对 话 框 如 图 4-72b. c 所 示 。 

















username 
password 
question 
anzwer 


truename 





单 选 掖 钮 组 : "sex" E EH “forml” v 


ERASE: [<?php echo Srow upuser[ sex | {Zi : LES 
: "x 
E: | 他 php echo $row upuser[' sex! ]; 7 























图 4-72 ”设置 “动态 单 选 按钮 ”对 话 框 
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动态 列表 / 羔 单 


"question" (E RÆ “forml” 
: |+| -J 
标签 


你 最 好 的 朋 ... 
你 小 学 上 学 
你 妈妈 的 名 
你 的 生日 是 





E B 记录 集 的 选项 : |upuser v 


: |question v 


| 
: [<?php $row upuser[' question | 到 














c) 
4-72 设置 “动态 单 选 按钮 ”对 话 框 《〈 续 ) 
(7) 单 击 “ 服 务 器 行为 ”面板 上 外 按 钮 ， 在 弹出 的 于 音 中， 选择 “更 新 记录 ”选项 ， 为 
网 页 添加 “更 新 记录 ”的 服务 砷 行为 ， 如 图 4-73 所 示 。 
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4-73 选择 “更 新 记录 ”选项 


(8) 打开 “更 新 记录 ”对 话 框 ， 该 对 话 框 与 “插入 记录 ”对 话 框 十 分 相似 ， 有 基体 的 设置 
情况 如 图 4-74 所 示 ， 这 里 不 再 复述 。 

(9) 设置 完成 后 ， 单 击 “ 人 确定” 按钮， 关闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 再 执行 苹 
单 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 到 本 地 站 点 中 。 


重点 提示 : 由 于 本 页 的 MM Username 值 是 来 自 上 一 页 注册 成 功 后 的 用 户 名 值 ， 所 以 单 
独 测试 是 会 提示 出 错 的 。 要 先 登 录 后 ， 在 登录 成 功 页 面 单 击 “ 修 改 您 的 注册 资料 ” 超 链接 到 
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该 页 面 才 会 产生 效果 ， 这 在 后 面 的 测试 实例 中 将 进行 介绍 。 





: | mymemb er 








member 


”合用 E ver aana, 作为 E paetae 
irr A ' FORM. password SSBBÍEM ， ER 
' question A ' FORM. question RREA TE 

'answer' M’ P answer’ XRHRBTEA ， ID 

'truename! 从: FORM. turename' 获取 值 作为 “ TE 

'sex' M’ FORM. sex WEYER ' 30A 

'address' JA 'FORM.address' REAR EE 


值 : FORM. username v | 
提交 为 : | 整数 vi xg 
在 更 新 后 ， 转 到 : userupdat eok. php | 



































图 4-74 设置 “更 新 记录 ”对 话 框 





4.42 更 新 成 功 页 面 | 


用 户 修 改 注册 资料 成 功 后 ， 就 会 转 到 userupdateok.php。 在 该 网 页 中 ， 应 该 同 用 户 显 示 
资料 修改 成 功 的 信息 。 除 此 之 外 ， 还 应 该 考虑 两 种 情况 ， 如 果 用 户 要 继续 修改 资料 ， 则 为 其 














提供 一 个 返回 到 userupdate.php 页 和 面 的 超 文 本 链接 ; 如 果 用 户 不 需要 修改 ， 则 为 其 提供 一 个 
转 到 用 户 登 录 页 面 index.php 页 面 的 超 文本 链接 。 有 其 体 的 制作 步骤 如 下 。 

CIO 执行 染 单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 userupdateok. 
php 的 网 页 并 保存 ， 在 第 一 行 加 入 如 下 代码 : 


<?php 
session start(); 
?>1/ 让 session 环境 局 动 。 


(2) 为 了 回 用 户 提 供 更 加 友好 的 界面 ， 应 该 在 网 页 中 显示 用 户 修改 的 结果 ， 以 供用 户 检 
答 修 改 是 否 正 确 。 首 先 应 该 定义 一 个 记录 集 ， 然 后 将 绑 定 的 记录 集 插入 到 网 页 中 相应 的 位 
置 ， 其 方法 跟 制 作 页 面 userupdate.php 的 方法 一 样 。 通 过 在 表格 中 添加 记录 集中 的 动态 数据 
对 象 ， 把 用 户 修改 后 的 信息 显示 在 表格 中 。 这 里 不 做 详细 说 明 ， 请 参考 前 面 一 小 节 内 容 ， 最 
终结 果 如 图 4-75 所 示 。 


PIJ 测试 修改 资料 


编辑 工作 完成 后 ， 就 可 以 测试 该 修改 资料 功能 的 执行 情况 了 。 

(1) 打开 正 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/index.php, 1]JT index.php 
文件 。 在 该 页 面 中 进行 登录 ， 登录 成 功 后 进入 welcome.php 页 面 ， 在 welcome.php 页 面 单 击 
“修改 您 的 资料 ” 超 链 接 ， 转 到 userupdate.php 页 面 ， 如 图 4-76 所 示 。 
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图 4-75 ”设计 “更 新 成 功 的 页 面 ” 


习 会 员 侨 改 页 面 - Nicrosoft Internet Explorer 

THFT AHE 查看 (WW) 收藏 由) IAT) 帮助 0) 

QAR- O-[9iàd st kx 6 O45 

地 址 部 ) D a btt: / 12T. 0.0. L/nenber eser dite ho makeer w|Egss we Qs Ey 


d» tid 


5 a ji 











购物 中 心 | 会 员 登 录 客户 留言 联系 我 们 








请 用 ^ 认真 修改 注册 | 言 息 ! 














请 再 次 确认 密码 填写 一 致 4 





admin 


OS OzR 








i il: designem(2153.com 
| 购物 流程 话 : 13800138000 


83560148 























1 选 购 产 品 
E 密码 提示 问题 : | 你 景 好 的 朋友 是 ? 
nd 密码 提示 答案 :wo | 


4.3858 | 


5. 签 收 产品 





BJ 


























4$ Internet 
图 4-76 修改 admin 用 户 注册 资料 


(2) 在 该 页 面 中 进行 一 些 修改 ， 然 后 单 击 “提交 ”按钮 ， 将 修改 结果 发 送 到 服务 占 中 。 
—€——— 浏览 器 会 转 到 userupdateok.php 页 面 中 ， 显 示 修 改 资 料 成 功 的 信 
县 ， 同 时 还 显示 了 该 用 户 修改 后 的 资料 信息 ， 并 提供 转 到 修改 成 功 页 面 和 转 到 主页 面 的 链接 对 
象 ， 这 里 对 “真实 姓名 ”进行 了 修改 ， 单 击 “ 修 改 ” 按 钮 转 到 修改 成 功 页 面 ， 效 果 如 图 4-77 
所 示 。 




















— 用 户 管理 系统 开发 


à 更 新 成 功 一 Nicrosoft Internet Explorer 加 回国 
TFP ”编辑 人 下) ”查看 0) REA 工具 (Ty 帮助 0 : 


QAE- O-iXi2(» DmsS* zk 6 A- SBL 
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1. 选 购 产 品 


2. 确 定 订购 密码 提示 问题 : | 你 最 好 的 朋友 是 ? 
3. 网 上 付款 SCRMBTUEX : lwo 

4 .填写 信息 : 重新 修改 MERN 

5. 签 收 产 品 : 


BJ 




















4-77 修改 成 功 
上 述 测试 结果 表明 ， 用 户 修改 资料 页 面 已 经 成 功 制作 。 
| Section. 


加 时” 密码 查询 模块 的 设计 


在 用 户 注 册 时 ， 页 面 设 计 有 密码 提示 问题 和 答案 文本 框 ， 其 作用 是 ， 当 用 户 和 未 记 密码 
时 ， 可 以 通过 这 个 问题 和 答案 到 服务 顺 中 找 回 遗失 的 密码 。 实 现 的 方法 是 判断 用 户 提 供 的 答 
案 与 数据 库 中 答案 是 售 相 同 ， 如 条 相同 ， 则 可 以 找 回 遗失 的 密码 。 


























IUE 密码 查询 XI 面 ZZ 


本 市 主要 制作 密码 合 询 负面 lostpassword.php， 具 体 的 制作 步骤 如 下 。 








(1) 执行 染 单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 lostpassword.php 
的 网 页 并 保存 。lostpassword.php 页 面 是 用 来 让 用 户 提交 所 要 查询 遗失 密码 的 用 户 名 的 页 面 。 
该 网 页 的 结构 比较 简单 ， 设 计 后 的 效果 如 图 4-78 所 示 。 

(2) 在 “文档 ”窗口 中 选中 表单 对 象 ， 然 后 在 其 对 应 的 “属性 ”面板 中 ， 在 “表单 名 
称 ” 文 本 框 中 输入 forml1， 在 “动作 ”文本 框 中 输入 showquestion.php 作为 该 表单 提交 的 对 
象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST 作为 该 表单 的 提交 方式 ， 如 图 4-79a 所 示 。 接 
下 来 将 输入 用 户 名 的 文本 域 命名 为 inputname， 如 图 4-79b 所 示 。 
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|| 购物 流程 


1. 选 购 产 品 
2. 确 定 订 购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产 品 











4—78 lostpassword.php X Hi 














Et 
T RA 动作 [showguestion pe — 710 — | (9 Bamw| — — v| 类 | 无 v 
Bik rr v) WENSH ~» 
a) 
尾 性 
加 X 字符 宽度 W) | 类 型 由 单行 (5) Osam OSME) SO | 无 xl 
最 多 字符 数 | | WMBODO 14 
口 禁 用 0) 
[]Ri£ R) 
b) 
图 4-79 设置 表单 提交 的 动态 属性 
重点 说 明 : 


表单 属性 设置 面板 中 的 主要 选项 作用 如 下 。 

1) 在 “表单 名 称 ” 文 本 框 中 ， 输 入 标志 该 表单 的 唯一 名 称 。 命 名 表单 后 ， 就 可 以 使 用 
脚本 语言 引用 或 控制 该 表单 。 如 果 不 命 名 表单 ， 则 Dreamweaver 使 用 语法 forml、from2、… 
生成 一 个 名 称 ， 并 在 向 页 面 中 添加 每 个 表单 时 递增 n VM. 

2) 在 “方法 ”下 拉 列 表 框 中 ， 选 择 将 表单 数据 传输 到 服务 器 的 方法 。POST 方法 将 在 
HTTP HR FRAR ŽA. GET 方法 将 表单 数据 附加 到 请 求 该 页 面 的 URL F, ÆRU 
置 ， 但 其 缺点 是 表单 数据 不 能 太 长 ， 所 以 本 例 选 择 POST 方法 。 

3 )“ 目 标 ” 下 拉 列 表 框 用 于 指定 返回 窗口 的 显示 方式 ， 各 目标 值 含义 如 下 : 

blank 在 未 命名 的 新 窗口 中 打开 有 目标 文档 。 

parent 在 显示 当前 文档 的 窗口 的 父 窗口 中 打开 有 目标 文档 。 

sef 在 提交 表单 所 使 用 的 窗口 中 打开 目标 文档 。 

top 在 当前 窗口 的 窗 体内 打开 目标 文档 。 此 值 可 用 于 确保 目标 文档 占用 整个 窗口 ， 即 使 
原始 文档 显示 在 框架 中 。 








QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





第 4 音 Q(CNRESEUELZI 





当 用 户 在 lostpassword.php 页 面 中 输入 用 户 名 ， 并 单 击 “提交 ”按钮 后 ， 这 时 会 通过 表 

单 将 用 户 名 提交 到 showquestion.php 页 面 中 ， 该 页 面 的 作用 就 是 根据 用 户 名 从 数据 库 中 找到 

对 应 的 记录 的 提示 问题 并 显示 在 showquestion.php 页 面 中 ， 用 户 在 该 页 面 中 输入 问题 的 答 

案 。 下 面 就 制作 显示 问题 的 页 面 。 | 
(3) 新 建 一 个 文档 。 设 置 好 网 页 属性 后 ， 输 入 网 页 标题 “查询 问题 ” MATRA "3c 记 

件 ” 一 “保存 ”命令 ， 将 该 文档 保存 为 showquestion.php。 
(4) 在 Dreamweaver 制作 静态 网 页 ， 完 成 的 效果 如 图 4-80 所 示 。 


























E C: \Apache\htdocs\member\showauestion. php (XHTML) * -0x 














mese | z 


1. 选 购 产 品 :该 用 户 名 不 存在 4 
2. 确 定 订购 : 
3. 网 上 付款 





< TIT 3 
<body> <table> <tr> <td> <form#forml > <p> [R] Q 100$  .|T25 x 421v 83 K / 2 $9 Unicode (UTF-8) 














图 4-80  showquestion.php FER I AUR 


(5) 在 “文档 ”窗口 中 选中 表单 对 象 ， 在 其 对 应 的 “属性 ”面板 中 ,“ 动 作 ” 文 本 框 中 
输入 showpassword.php 作为 该 表单 提交 的 对 象 页 面 。 在 “方法 ”下 拉 列 表 框 中 选择 POST fF 
为 该 表单 的 提交 方式 ， 如 图 4-81a 所 示 。 接 下 来 将 输入 密码 提示 问题 答案 的 文本 域 命名 为 
inputanswer， 如 图 4-81b 所 示 。 




















BIE 


[7l 表单 ID 动作 showpassword.php 号 目标 (T) | v | 2$ (C) | 无 v 
: Jr [ros vi GEZE Y 












































a) 
Ir 文本 域 字符 宽度 | 类 型 Oge Osam — Oso 类 (C) 无 v 
景 多 字符 数 | ”| 初始 值 (I) | | 多 
OSAM) 
[ ] Rit () 
b) 


图 4-81 设置 表单 提交 的 属性 
(60 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 该 面板 上 [二 按钮 ， 


从 打开 的 玉音 中 选择 “记录 集 (查询 )” 选 项 ， 则 会 打开 “记录 和 集 ”对 话 框 。 
(7) 在 该 对 话 框 中 进行 如 下 设置 。 
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1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 选择 数据 源 连接 对 象 为 mymember。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 member. 

4) 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 从 下 拉 列 表 框 中 选择 username 和 
question 。 

5) 在 “和 沛 选 ” 栏 中 ， 设 置 记录 集 过 滤 的 条 件 为 username: =， 表 单 变 量 : inputname， 
表示 根据 数据 库 中 username 字段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 inputname 表单 对 象 所 
传递 过 来 的 信息 完全 一 致 ， 来 过 滤 记 录 对 象 。 

完成 后 的 设置 如 图 4-82 所 示 。 


























名 和 i 
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图 4-82 设置 “记录 集 ” 对 话 框 


(80 设置 完成 后 ， 单 击 该 对 话 框 上 的 “确定 ”按钮 ， 关 财 该 对 话 框 。 返 回 到 “文档 ”窗口 。 
(9) 将 Recordsetl 记录 集中 的 question 字段 绑 定 到 页 面 中 相应 的 位 置 ， 如 图 4-83 所 示 。 
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1. 选 购 产 品 该 用 户 名 不 存在 
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(100. 执行 业 单 “插入 记录 ”一 “表单 ”一 “隐藏 域 ”命令 ， 在 表单 中 插入 一 个 表单 隐 
藏 域 ， 然 后 将 该 隐藏 域 的 名 称 设置 为 username. 

(11) 选中 该 隐藏 域 ， 转 到 “ 绑 定 ”面板 ， 将 Recordsetl 记录 集中 的 username 字段 绑 定 
到 该 表单 隐 荐 域 中 ， 如 图 4-84 所 示 。 





LB ERË (Recordzetl) 


: 4 ^ question 


| s$ ession 





e 
H: 4php echo $row Recordzetl['useri 








图 4-84 username 字段 绑 定 到 表单 隐藏 域 


重点 提示 : 当 用 户 输 入 的 用 户 名 不 存在 时 ， 即 记录 集 Recordsetl 为 空 时 ， 就 会 性 致 该 页 
面 不 能 正常 显示 ， 这 就 需要 设置 隐藏 区 域 。 


(12) 在 “文档 ”窗口 中 选中 当 用 户 输 入 用 户 名 存在 时 显示 的 内 容 即 整个 表单 ， 然 后 单 
击 “ 服 务 器 行为 ”面板 上 [ 填 按 钮 ， 在 弹出 的 菜单 中 ， 执 行 “ 显 示 区 域 ” 一 “如 果 记 录 集 不 
为 空 则 显示 区 域 ” 命 令 ， 则 打开 “如 果 记 录 和 集 不 为 空 则 显示 区 域 ”对 话 杠 ， 在 该 对 话 框 中 选 
择 记 录 集 对 象 为 Recordset1。 这 样 只 有 当 记 录 集 Recordsetl 不 为 容 时 ， 才 显示 出 来 。 设 置 完 
成 后 ， 单 击 “ 确 定 ” 按 钮 ， 如 网 4-85 所 示 。 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 





























MI Iac SE T 29 Z7 MI os Dx 38 





图 485 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 


(13) 在 网 页 中 编辑 显示 用 户 名 不 存在 时 的 文本 “该 用 户 名 不 存在 !”， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ” 隐 藏 区域 服务 喜 行 为 ， 这 样 当 记录 集 Recordsetl 为 空 
时 ， 显 示 这 些 文 本 ， 完 成 后 的 网 页 如 图 4-86 所 示 。 


eso 完善 密码 查询 功能 


























当 用 户 在 showquestion.php 页 面 中 输入 管 案 ， 早 击 “ 提 区 ”按钮 后 ， 服 务 器 束 会 把 用 户 


名 和 密码 提示 问题 答案 提交 到 showpassword.php 页 面 中 。 
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T C: Apache Vhtdocsimemberlshowquestion.php (XHTML)* .Dx 


HR mymember. php 





| 购物 流程 





1. 选 购 产 品 

2. 确 定 订购 : EREGEDESUUEZGM 
3. 网 上 付款 ORE ak RIS E 

4. 填 写 信 息 : 








Qo <table> DG (RIM Q 100& v T5 x 403v 8T K / 2 P Unicode OF-6) 
4-86 ix Ec DX 
下 面 介绍 如 何 设计 该 页 向 ， 有 其 体制 作 步 又 如 下 。 
(1) 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 在 网 站 根 目 录 下 新 建 一 个 名 为 showpassword. 


php 的 网 页 并 保存 。 
(2) 在 Dreamweaver 中 使 用 提供 的 制作 静态 网 页 的 工具 ， 完 成 如 图 4-87 所 示 的 静态 部 分 。 








四 C: XApachekhtdocshmemberkshowpassword.php (XHTML) 








| 对 不 起 多 输入 的 符 案 不 正确 ,请 间 击 这 里 重新 输入 


| 购物 流程 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信息 








ko s n — | i] 
R| Qj 100% — v T25 x 427v 83 K / 2# Unicode (UTF-8) 


4-87  showpassword.php 静态 设计 


(30 JT. "ELI" — HE do. FTIF AWE” IB, ÉME [TT 
在 弹出 的 菜单 中 选择 “记录 集 (查询 )” 选 项 ， 则 会 打开 “记录 集 ” 对 话 框 。 

(4) 在 该 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 

2) 从 “连接 ”下 拉 列 表 框 中， 选择 数据 源 连 接 对 象 
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3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 member. 

4) 在 “ 列 ” 栏 中 选择 “ 选 定 的 ” 单 选 按钮 ， 然 后 选择 字段 列表 框 中 的 username, 
password 和 answer 等 3 个 字段 束 行 了 了 。 

5) 在 “筛选 ” 栏 中 设置 记录 集 过 滤 的 条 件 : answer 为 =， 表 单 变量 为 inputanswer, X 
示 根 据 数据 库 中 answer 字段 的 内 容 是 否 与 从 上 一 个 网 页 表单 中 的 inputanswer 表单 对 象 传递 
所 过 来 的 信息 是 否 完全 一 致 来 过 滤 记 录 对 象 。 

完成 的 设置 情况 如 图 4-88 PTR. 




















s. 
ei. 


xj O 全 部 © 选 定 的 : 





anzwer b 
m: 








图 4-88 设置 “记录 和 集 ” 对 话 框 


(5) 单 击 “ 确 定 ” 按 钮 ， 关 闭 该 对 话 框 ， 返 回 到 “文档 ”窗口 。 
C6) 将 记录 集中 username 和 password 两 个 字段 分 别 添 加 到 网 页 中 ， 如 网 4-89 所 示 。 





T c:Whpachevht docsAmemberkshowpassword php (XHTML)* 


€T mymember. php 
^w, 





|| 购物 流程 


1. 选 购 产品 
2. 确 定 订购 
3. 网 上 付款 
4.385518 8. 
5. 签 收 产品 


< | lll] 
<body> «table? <tr> <td> <table> Ctr? <td> <p> CIE Q, 100% v725 x 403v 86 K / 2 fh Unicode (UTF-8) 














图 4-89 加 入 的 记录 集 效 果 





(7) 同样 需要 根据 记录 集 Recordsetl 是 否 为 衬 ， 为 该 网 页 中 的 内 容 设置 隐藏 区 域 的 服务 
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器 行为 。 在 “文档 ” 寄 口 中 ， 选 中 当 用 户 输 入 密码 提示 问题 答案 正确 时 显示 的 内 容 ， 然 后 单 
击 “ 服 务 器 行为 ”面板 上 [ej 按钮， 在 弹出 的 菜单 中 ， 执 行 “ 显 示 区 域 ” 一 “如 果 记 录 和 集 不 
为 空 则 显示 区 域 ” 命 令 ， 打 开 “ 如 果 记 录 集 不 为 容 则 显示 区 域 ” 对 话 框 ， 在 该 对 话 框 中 选择 
记录 集 对 象 为 Recordset1。 这 样 只 有 当 记 录 集 Recordsetl 不 为 衬 时 ， 才 显示 出 来 ， 如 几 4-90 
所 示 。 设 置 完成 后 ， 单 击 “ 人 确定 ”按钮 ， 关 闭 该 对 话 框 ， 人 返回 到 “文档 ”窗口 。 
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4-90 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 
C8) 在 网 页 中 选择 当 用 户 输 入 密 但 提示 问题 答案 不 正确 时 显示 的 内 容 ， 并 为 这 些 内 容 设 
置 一 个 “如 果 记 录 集 为 空 则 显示 区 域 ”隐藏 区 域 服务 嚣 行为， 这样 当 记录 集 Recordsetl HE 
时 ， 显 示 这 些 文本 ， 如 图 4-91 所 示 。 
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图 4-91. “如 果 记 录 集 为 空 则 显示 区 域 ” 对 话 框 


(9) 完成 后 的 网 页 如 图 4-92 所 示 。 执 行 染 单 “ 文 件 ” 一 “保存 ”命令 ， 将 该 文档 保存 
到 本 地 站 点 中 。 


5 C: \hpache\htdocs\member\showpassword. php (XHTML)* -0X 


CHAT mymember. php 


EI 


: 购物 流程 : 用 户 : (Recordsetl usemame) 


1 . 选 购 产品 | 密码 : {Recordsetl password) 
2. 确 定 订购 
3. 网 上 付款 
4. 填 与 信息 
5. 签 收 产 品 


单 击 这 里 重新 登录 


gj j > 


- — 
body? <table> Ctr? <td> Kr) R] Q 100€ v7T25 x 403v 8T K / 2 fh Unicode (UIF-8) — - 








图 4-92 ”完成 后 的 网 页 效果 图 
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用 户 管 理 系 统 开 发 





epe 测试 密码 查询 功能 





开发 完成 后 ， 就 可 以 测试 密码 查询 功能 的 执行 情况 了 。 
(1) 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http://127.0.0.1/member/index.php， 打 开 index.php 
文件 。 单 击 该 页 面 中 的 “拷问 密码 ” 超 文 本 链接 ， 如 图 4-93 所 示 的 页 面 。 
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图 4-93 输入 要 查询 的 用 户 名 


(20 当 用 尸 进入 密 介 得 询 页 面 lostpassword.php 后 ， 输 入 并 辣 服 务 占 提交 目 己 注册 的 用 
户 名 信息 。 当 输入 不 存在 的 用 户 名 ， 并 单 击 “ 提 交 ” 按 钮 ， 则 会 转 到 showquestion.php 页 
面 ， 该 页 面 显 示 出 用 户 名 不 存在 的 错误 信息 。 
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图 4-94 输入 的 用 户 名 不 存在 
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(3) 如 果 输 入 一 个 数据 库 中 已 经 存在 的 用 户 名 ， 然 后 单 击 “ 提 交 ” 投 钮 。 正 Vnd H 
动 转 到 showquestion.php WH, WKI 4-95 所 示 。 下 面 就 应 该 在 showquestion.php 输入 密码 提 
不 问题 答案 ， 测 试 showquestion.php 网 页 的 执行 情况 。 








c 查询 问题 bd BAK 
XF MEE ”查看 0) EAO IAM) #8) 
OAE- O- NAOI kear 6 O-a 34 











地 址 部 ) 名 Aa dt D. D. 1/member/ showquestion. php 所 输入 关键 司 搜索 v| 转 到 ”链接 o SnagIt ES 


gc 


| 购物 流程 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 与 信息 


5. 签 收 产品 





^ 





ESL 
查询 问题 


:问题 提示 : 你 最 好 的 朋友 是 ? 














联想 手提 电脑 


团购 特惠 


(AD Internet 


4-95 showqeustion.php 网 页 效果 图 


(4) 在 这 里 可 以 先 输入 一 个 错误 的 答案 ， 检 杜 showpassword.php 中 是 否 能 够 显示 密码 所 
示 问 题 的 答案 不 正确 时 的 错误 信息 ， 如 图 4-96 所 示 。 


A EA — Hicrosoft Internet Explorer 
AEG) mD sem REA IAM #0 
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地 址 部 ) &] http: //12T. 0. 0. 1/member/showpassword. php 所 输入 关键 司 搜索 ~] 转 到 “ 链接 o SnagIt ES 
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| 购物 流程 


1. 选 购 产 品 
2. 确 定 订购 
3. 网 上 付款 
4. 填 写 信 息 
5. 签 收 产品 








^ 





联系 我 们 
| 特别 推荐 


| 对 不 起 您 输入 的 答案 不 正确 ,请 单 击 这 里 重新 输入 4 


联想 手提 电脑 


(AD Internet 


图 4-96 出错 信息 








用 户 管 理 系 统 开 发 


(5) 如 果 在 showquestion.php 网 页 中 输入 正确 的 答案 ， 并 单 击 “提交 ”按钮 后 ， 浏 览 器 
就 会 转 到 showpassword.php 页 面 ， 并 显示 出 该 用 户 的 密码 来 ， 如 图 4-97 所 示 。 
DER 

L| 





SEA: 一 IcCroso ft Internet Explorer 
TFP mE ERE) 收藏 人 工具 (T) #80) 
OAE- O- NDO ka e O-R o € 


地 址 部 ) E] http: //127. D. D. 1/member/showpassword. php hc M 转 到 ”链接 © SnagIt EJ 
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客户 留言 联系 我 们 








| 特别 推荐 


用 户 : admin 


密码 : 111111 ~ 
联想 手提 电脑 


购物 流程 单 击 这 里 重新 登录 : x 


2 .确定 订购 : 索尼 数码 相机 
3. 网 上 付款 : : 

4. 填 写 信息 : : ba 
5. 签 收 产 品 











4-97 showpassword.php 页 面 


(60 上 述 测试 结果 表明 ， 和 密码 便 询 系统 已 经 成 功 制作 。 
全 此 ， 用 户 管 理 系统 的 利用 功能 都 已 经 设计 完成 并 测试 成 功 ， 设 计 者 如 宋 需 要 将 其 应 用 
到 其 他 的 网 站 上 ， 只 需要 与 设计 的 页 和 面 配 合 ， 修 改 一 些 相 关 的 文子 说 明 及 背景 效果 ， 束 可 以 


，; 人 


完成 用 户 管理 系统 的 制作 。 
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第 司 发 布 系统 开发 


新 闻 发 布 系统 是 动态 网 站 建设 中 经 常用 到 的 系统 ， 尤 其 是 在 政府 单位 、 教 育 单位 或 企业 
网 站 。 新 闻 发 布 系统 的 作用 就 是 在 网 上 传播 信息 ， 通 过 对 新 闻 的 不 断 更 新 ， 让 用 户 及 时 了 解 
行业 信息 、 企 业 状 况 。 所 以 新 闻 发 布 系统 中 所 涉及 的 主要 操作 就 是 访问 者 的 新 闻 查 询 功能 和 
系统 管理 员 对 新 闻 的 新 增 、 修 改 、 删 除 功能 ， 使 用 PHP 实现 这 些 功能 相对 比较 简单 。 





EB 新 














MATIE E 


主要 掌握 以 下 知识 所 : 


新 闻 发 布 系 统 网 页 结构 的 整体 设计 


新 闻 系 统 效 据 库 的 规划 

新 闻 发 布 系 统 前 台新 闻 发 布 功 能 页 面 的 制作 
新 闻 发 布 系统 分 类 功能 的 设计 

新 闻 发 布 系统 后 台新 增 、 人 修改、 删除 功能 的 实现 





pO ELELEE 








= lala 
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系统 的 整体 设计 规划 


网 站 的 新 闻 发 布 系 统 ， 在 拉 术 上 主要 体现 为 如 何 显 示 新 闻 内 容 ， 以 及 对 新 闻 及 新 闻 分 类 
的 修改 和 删除 。 一 个 完整 的 新 闻 发 布 系 统 共 分 为 两 大 部 分 ， 一 个 是 访问 者 访问 新 闻 的 动态 网 
页 部 分 ， 万 一 个 是 过 理 者 对 新 闻 进 行 编辑 的 动态 网 页 部 分 。 新 闻 发 布 系统 的 结构 岁 如 网 5-1 
所 示 。 




















新 闻 发 布 系统 


index.php 
访问 者 页 面 


admin login.php admin.php 


type. add. php || type upd. php || type del. php || news add.php || news upd.php || news del.php 


图 5-1 痢 闻 发 布 系统 结构 图 
本 系统 页 面 共 有 11 个 ， 整 体系 统 页 面 的 功能 与 文件 名 称 如 表 5-1 所 示 。 


里 者 页 面 


1R 
H 


表 5-1 新 闻 发 布 系统 开发 网 页 设计 表 








需要 制作 的 主要 页 面 x 能 
新 闻 首页 显示 新 闻 分 类 和 最 新 新 闻 页 面 

浙 闻 分 类 页 面 显示 新 闻 分 类 中 的 新 闻 标题 页 面 
浙 闻 内 容 页 面 显示 新 闻 内 容 页 而 

台 管 理 入 口 页 面 管理 者 登录 入 口 页 面 

后 台 管 理 主页 面 对 新 闻 进 行 管理 的 主要 页 面 
浙 增 新 闻 页 面 增加 新 闻 的 页 面 
修改 新 闻 页 面 修改 新 闻 的 页 面 
删除 新 闻 页 面 删除 新 闻 的 页 面 

浙 增 新 闻 分 类 页 面 增加 新 闻 分 类 的 页 面 

修改 新 闻 分 类 页 面 修改 新 闻 分 类 的 页 面 

删除 新 闻 分 类 页 面 删除 新 闻 分 类 的 页 面 


页 面 设计 规划 


在 本 地 站 点 上 建立 站 点 文件 来 news， 将 要 制作 的 新 闻 发 布 系统 文件 夹 和 文件 建 并 如 
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| 5-2 Biz. 


* C: XApacheVhtdocsVnews SA 
文件 @) MED SEV KAA IAM 800 EF 
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地 址 0) |Ø C: Apachevhtdocsvnews 


文件 和 文件 夹 任 务 。 [和 】 p 区 un 


C9 创建 一 个 新 文件 来 
Q 将 这 个 文件 来 发 布 到 多 
Web 1 data 
共享 此 文件 夹 
| index. 
images Ky: PHP rb 








"m scontent.php EE o e. 


x 文件 《 «P: ne ;H 


8 THR 7.34 理 | 早 我 的 电脑 





新 闻 发 布 系 统 主要 起 到 了 宣传 的 作用 ， 实 例 中 在 色调 上 选择 更 色 和 绿色 作为 主 色调 。 由 
于 本 书 主 要 讲述 使 用 Dreamweaver 开发 PHP 的 方法 ， 所 以 网 页 的 美工 设计 相对 比较 简单 ， 
P HW index.php 效果 如 图 5-3 所 示 。 
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5-3 HEA index.php ZUR Fd 











新 闻 发 布 系统 开发 
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数据 库 设计 与 连接 


制作 一 个 新 闻 发 布 系统 ， 首 先 要 设计 一 个 储存 新 闻 内 容 、 管 理 员 账 志和 密码 的 数据 库 文 
件 ， 方 便 管 理 人 员 对 新 闻 数 据 信 息 进 行 管理 和 完善 。 





521 | 新 闻 效 据 库 设 计 

新 闻 发 布 系统 需要 一 个 用 来 存储 新 闻 标 题 tle 和 新 闻 内 容 content 的 新 闻 信 息 表 ， 还 要 
建立 一 个 新 闻 分 类 表 和 一 个 管理 信息 表 ， 分 别 命名 为 news. newstype. admin 数据 表 。 制 作 
的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", 进入 MySQL 数据 库 的 管理 面 
板 ， 如 图 5-4 所 示 。 


E SQL 下 amager 2007 for MySQL 




















Database View Tools Services Plugins Options Windows Help 
; ] : iaia ae 


- Getting Started 


S- localhost (b Create new database 
ld mysal on localhost 
m Manage existing database(s) 
Database Tools 
g Execute SQL script 
e3 Manage users 
: Help and Support 


(9 SQL Manager 2007 help system 





(9 MySQL reference 


—. Internet Resources 


的 SQL Manager 2007 home page E. Support Center 


G SQL Manager 2007 on-line documentation Q SQL Manager 2007 FAQ 








5-4 打开 MySQL 数据 库 管 理 界面 


(2) 单 击 工 具 栏 的 Create. CHO 按钮 ， 并 在 打开 的 下 拉 沫 单 中 单 击 选择 “DataBase 
数据库)” 命 令 ， 如 图 5-5 所 示 。 

(3) 打开 “Create Database Wizard 〈 建 立 数 据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“news”。 然 后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 5-6 Dr. 

(4) 设置 MySQL 数据 库 的 连接 设置 如 表 5-2 以 及 如 图 5-7 所 示 。 然 后 再 单 击 Next (下 
一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 

















Create Database Wizard 


Create Database 


Specify the name for a new database 


Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SOL statement for creating the database and execute it 
on MySQL server. 





Database name news 





Register after creating 








5-5 #m "Database" fi 5-6 输入 数据 库 的 名 称 news 


表 5-2 数据 库 连 接 设 置 


User name root 


Password admin 


Create Databaze Wizard 
Create Database 


Set connection praperies For a new database 


Host name localhost v Port 3308 7 


User name ront 


— Manager 


—— forMySQL [C_| Use tunneling 
LN Tunneling 
SSH tunneling HTTF tunneling 





图 5-7 连接 设置 


(5) 打开 新 建 数 据 库 的 SQL 语句 提示 ， 创 建 数据 库 news, H Next (下 一 步 ) Ja 
钮 ， 如 图 5-8 所 示 。 

(6) Hh Finish CER) 按钮， 打开 注册 数据 库 的 设置 画面 ， 选 择 utf8 字符 集 、 人 简体 中 
文 版 的 GB2312 版 ， 其 他 的 你 持 献 认 值 ， 如 图 5-9 所 示 。 





新 闻 发 布 条 统 开发 


Create Database Wizard 
Create Database 


Hesult SOL statement. Click the Finish button to create a new database. 


Fiezult SaL statement: 
CREATE DATABASE "newz'; 


* Connection 


Display Options Host name 

[— Directories User name 
Logz 

(f$ SSH Tunneling 
HTTP Tunneling Hielo mete 


Data Options 


Password 


Database alias 


Client charset 


Font charset 


图 5-9 ”选择 简体 中 文 


CI) AROK MAA) 按钮 ， 束 完成 了 数据 库 news 的 狐 增 工作 。 

数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 
news、newstype、admin。 建 并 数据 表 后 ， 接 着 再 单 击 左 边 的 “Connect to Database. (连接 数 
HE” BHA 将 其 连接 上 。 这 两 张 数 据 表 的 字段 结构 内 容 说 明 如 下 。 

(1) 建立 数据 库 news 后 ， 用 鼠标 右键 单 击 选择 “Table〈 表 格 )” 选 项 ， 在 打开 的 荣 单 
中 单 击 选择 “New Table OKIE)” ME, WK 5-10 所 示 。 















IPHP+ 


# SQL Wanager 2007 for NySQL — news on localhost [news] 
Database View Tools Services Plugins Options Windows Help 


日 Q localhost 
m member on localhost 
5-H news on localhost 


òc Hr] 7 Br 


2 Getting Started 





Ek Create new database 


m Manage existing database(s) 





7 Execute SQL script 





| [93 New Tab from Here... 


Rename Current Tab.. 





Delete Current Tab 


Find Item... 





i ocalhostnews on localhostiTables 
: Tables 


news， 如 图 5-11 所 示 。 


Ta Manage users 


p and Support 





€) SQL Manager 2007 help system 
(9 MySQL reference 


Internet Resources 





的 SQL Manager 2007 home page 


SQL Manager 2007 on-line documentation 
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[rs Create new table 


[r4 Create new database object 


区 | Execute query 


$» Manage permissions 


S Support Center 


Q SQL Manager 2007 FAQ 


5-10 ”开始 建 数 据 表 


(2) 数据 库 右 方 界 面 会 出 现 新 建 数据 表 (Table) 的 设置 区 域 ， 含 有 “Table《〈 表 格 )” 
“Fields (内 容 )”“DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 


a New Table — [news on localhost] 


S news on localhost [news] + 


| iF Compile 
9 Show SL help 
国 Restore default size 





Fields | DDL 


Table Properties 


Table name news 
Storage Optionz 
Storage engine 
Row format 
Min. rows 

Max. rows 

Auto increment value 
Average row length 
Size for index key blocks 
[| Check sum 

[ ]Pack keys 


| | 
x5 
pP 
E| E 
m| Z 
一 | 

4| € 


I 
m 
pai] 

-Z 
- 
qm 

-2 
三 
x 
ES 
iD 


mm 
p] 
3 
Ea 
a 
Sa 
zn 
= 
= 


Character Sets | File Options || Merge Table Options | Federated Table Options 


Character set 


Callation 





年 
ca 
&|* 


5-11 输入 数据 表 名 news 


G) 然后 再 切换 到 “Fields 内容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设 症 数据 域 位 的 相关 
数据 ， 如 表 5-3 及 图 5-12 Bros. 
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表 5-3 新 闻 信 息 数据 表 news 


£ Table — [news] — [news on localhost] mef) 








Object e ^l | Properties | Fields | Indices | Triggers | Data | Dependencies | DDL 





Field Name Field Type Size Precisi... Not Null Default Comment | 
| BJ news on localhost nes v E Y INTEGER |20 |o | m INDE 
E ems news title VARCHAR (50 0 Null 
Ez: newes type VARCHAR 20 Null 
& news_content TEXT 0 Null 
[a] Refresh news date DATE 0 Null 
学 Compile ij newes author VARCHAR 20 Null 
Qs Grants on table 

















General 


[3 [SI E [SI [S] 


& Print 

©) Show SQL help 

(d Table Editor options 
回 Restore default size 


Tools 


E Truncate table 


Fields 


Sg Add new field 
ig Edit selected field 
Eg Drop selected field(s) 


Explorer 
(2-85 Fields (5) 











图 5-12 ”设置 数据 库 


(4) 同样 创建 newstype 数据 表 ， 用 于 储存 新 闻 分 类 用 ， 输 入 数据 域名 以 及 设置 数据 域 
位 的 相关 数据 ， 如 表 5-4 及 图 5-13 Br. 


表 5-4 新 闻 分 类 信息 数据 表 newstype 





(5) 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 表 5-5 及 图 5-14 所 示 。 





表 5-5 管理 信息 数据 表 admin 
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a Table — [newstypel — [news on localhost] mn 回 Ed 


Object A Properties | Fields |Indices | Triggers | Data | Dependencies | DDL 
Field Mame | Field Type Size Prec... Mot ... Defaut | Comment 


Biverme wwowm o LEI 


| le] Refresh 
学 Compile 
is Grantz on table 
gza Print 
9 Show SOL help 
qi Table Editor options 
国 Restore default size 





5-13 ”创建 newstype 数据 表 


g Table — [admin] — [news on localhost] 回回 因 
Object 全 Properties | Fields Indices | Triggers | Data | Dependencies DDL 


Field Name Field Type Size Precis... Mot Null Default . Comment 
INTEGER 11 











| E news on localhost [ne* v 


BB admin v 


[a] Refresh 
学 Compile 
Jo Grants on table 














ca Print 

©) Show SQL help 

d Table Editor options 
加 Restore default size 


Tools 


E Truncate table 

















5-14 创建 admin 数据 表 


在 创建 上 述 的 3 个 数据 表 时 ， 其 中 涉及 到 新 闻 保存 时 的 时 间 问题 ， 使 用 PHP 实现 获取 
系统 默认 即时 时 间 ， 可 以 使 用 两 种 方法 实现 ; 一 种 是 在 网 页 PHP. 中 用 date0 和 time0 函 数 实 
现 ， 另 一 种 是 直接 用 MySQL. 数据 库 中 的 NowO 时 间 。 考 虑 到 如 果 后 期 数据 量 大 减少 服务 器 
的 工作 量 ， 优 先 采 用 在 网 页 使 用 PHP 获取 时 间 的 方法 。 具 体 的 实现 方法 在 新 增 新 闻 页 面 的 
设计 时 会 讲 到 。 


JOAN 定 Xnewsi 点 OO 


在 Dreamweaver CS 5.5 中 创建 一 个 “新 闻 发 布 系统 ”网 站 站 点 news， 由 于 这 是 PHP 数 
气 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 设置 如 表 5-6 所 示 。 
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表 5-6 站 点 设置 的 基本 参数 


站 点 名 称 news 
本 机 根 目 录 CAApacheMtdocsnews 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhost/news/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataNMySQLAMYyYSQL Server 5.5\datanews 
管理 账号 / 密码 root / admin 
数据 库 名 称 news 


创建 news 站 点 具体 操作 步骤 如 下 。 
(1) 首先 在 C:\Apache\htdocs 路 径 下 建立 news 文件 来， 如 图 5-15 所 示 ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


Capachexhtdocs PB) 
Ld 


TED REO 查看 (VW) BEA IAM 帮助 
QAE- O- JPs5* DHR m 


地 址 m) |Ø C: \Apachethtdocs v E55 
A 名 称 和 修改 日 期 
YfERUYTEXHES [o omnServerScripts 2011-7-6 16:06 
x BS nenber 2011-7-7 22:04 
=j EE XE PES 2011-7-8 10:40 
(Gy 移动 这 个 文件 夹 Ø rh 2011-6-15 9:41 
[D 复制 这 个 文件 来 个 phpWykdnin 2011-7-4 9:35 
Q 将 这 个 文件 到 发 布 到 了 2011-6-30 15:30 
dad B test 2011-7-6 15:55 
ka] HFHH Æ] index. html 2004-11-20 15:16 


a ETAD E t test. php 2011-7-6 8:35 
K eso TEX 














5-15 建立 站 点 文件 夹 news 


(2) 运行 Dreamweaver CS .35， 选 择 菜 单 栏 中 的 “站 点 ?” 
一 “管理 站 点 ”命令 ， 打 开 “ 管 理 站 点 ”对 话 框 ， 如 图 5-16 
所 示 。 

(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 经 
定义 的 站 点 。 单 击 右边 的 “ 狐 建 ”按钮 ， 打开“ 站 点 设置 对 
象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”: news. 

“本 地 站 点 文件 来” CNApacheMtdocsnews. 

如 图 5-17 所 示 。 




















5-16 “管理 站 点 ”对 话 框 
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站 点 设置 对 锡 news 
Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Drearmweaver 


站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文 件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 支 布 到 web 上 的 服务 器 上 的 远程 文件 来 。 


您 可 以 在 此 处 泊 Dreamweaver 站 点 选择 本 地 站 件 夹 和 名 称 。 
站 点 名 称 ; 
zE Hh s c reb: | CApachethtdocsinewsl 5 





K] 5-17 建立 news 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 [二 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 5-18 所 示 的 参数 设置 。 

“IRIRE”: news. 

“连接 方法 ” 本地/ 网络 。 

“服务 器 文件 来” C:\Apache\htdocs\。 

“Web URL”: http:// localhost/ news/. 


站 点 设 下 对 锡 news 








服务 器 名 称 ， 
连接 方法 
Was [Cis S 

















图 5-18 设置 “基本 ”选项 卡 








(50 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同 步 
信息 ” 复 选 按钮 ， 在 “服务 需 模 型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 5-19 Brzn. 











新 闻 发 布 条 统 开发 


站 点 设置 对 旬 news 


版 本 控制 
> 高 级 设置 M 锥 护 同步 信息 
口 ] 保存 时 自动 将 文件 上 传 到 服务 器 
C] 启用 交 件 职 出 功能 
[V] 打开 文件 之 前 取出 


REZE: OOO 
电子 邮件 地 址 : 











5-19 设置 “高 级 ”选项 卡 


(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选 择 “ 测 试 ” 复 选 按钮 ， 
如 图 5-20 所 示 。 


站 点 设置 对 锣 news 

— un 

您 将 在 此 位 置 选 择 兴 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web 管理 员 。 


* ”高 级 设置 





注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 | web 并 发 
布 页 面 ， 您 只 需 定 必 一 个 远程 服务 器 即 可 。 





名 称 | 地址 | 连接 | 远程 测试 | 
news CiApachejhtdocs 本 地 | 网 络 [V M 


5-20 设置 “服务 器 ”参数 

单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 

才 所 设置 的 站 点 news。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 就 完成 了 
Dreamweaver CS 5.5 测试 新 闻 发 布 系统 网 页 的 网 站 环境 设置 。 


323 设置 数据 库 连 接 
完成 了 站 点 的 定义 后 ， 接 下 来 就 是 新 闻 发 布 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 


库 的 连接 设置 如 下 。 
(1) 将 光盘 中 本 章 文 件 复制 到 站 点 文件 夹 下 ， 打 开 index.php, WE 5-21 所 示 。 
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Dw 


| aHa | E T) O cw foak 
THI SE 查看 (Y) 插入 (IT) ER AO 命令 (C) 站 点 (3) EQ 帮助 (D 





C:\Apache\htdocs\news\indez. php 


m news. pho 


T B ne 本 地 视图 w 

: HB 
Poesie D] a [3t] | ERHERS | p** [d 实时 视图 | 检查 MM O. SREI A C &elàáovag8|" 
iGo C qi x 3 
































NEWS 
PHP 新 闻 系 统 





RY Q 1008  . 739 x 475v 53 K / 2 19 Unicode (VIF-8) 





BRO) [无 

E css ID(I) 无 IC 目标 (c) 
国 单元 格 KEDR TATOO FAME G) [ .| erre TERE. m " 
E k> " : — 
cst $80! 标题 L 1 个 本 地 项 目 被 选中 ,总 
















































































5-21 打开 网 站 首页 index.php 


(2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 
令 ， 打 开 “ 数 据 库 ”面板 。 在 “数据 库 ” 面 板 ， 单 击 选择 
“+ ”图标 ， 并 在 打开 的 菜单 中 选择 “MySQL Xie" up EE 
项 ,如 图 5-22 Bi. 

(3) Æ “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 4 
称 ” 为 news, *MySQL 服务 器 ”名 为 localhost,“ 用 户 
名 ”为 root， 密 码 为 admin, JE 5-23a 所 示 。 选 择 所 要 ”图 5-22 选择 “MySQL 连接 
建立 连接 的 数据 库 名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 
择 刚 建立 的 范例 数据 库 news， 有 具体 的 设置 内 容 如 图 5-23b 所 示 。 








7SQL 连接 








定 à : [book 
连接 名 称 : news db shop 
3 inf ti h 
MySQL 服务 器 : localhost 1n ber lon schema 
用 户 名 : root 


performance schemaold 
SrhH. eek 


数据 库 : news 





















































图 5-23 WE “MySQL 连接 ”参数 


(4) 单 击 “ 测 试 ” 按 钮 来 测试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 来 正确 则 会 出 一 个 
消息 枉 ， 如 网 5-24 所 示 ， 表 示 数 据 库 连接 设置 成 功 了 。 
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单 击 “ 确 定 ” 按 钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 和 面板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 5-25 所 示 。 


数据 库 





NySQL 连接 % 
DO AE *, 一 文档 类 型 : Pe e ©) 
~A 


脚本 编制 b 
a i admin ` 





连接 名 称 : 
MySQL 服务 器 : 
用 户 名 : root 

密码 : 

数据 库 : 








图 5-24 设置 成 功 图 5-25” 绑 定 的 数据 库 


系统 页 面 设计 


狐 闻 发 布 系统 前 台 部 分 主要 有 3 个 动态 页 面 ， 分 别 是 狐 闻 主页 面 mdex.php， 新 闻 分 类 页 
而 type.php， 狐 闻 内 容 页 而 newscontent.php。 


SE 新 闻 发 布 系统 首页 设计 














在 本 小 节 中 主要 介绍 新 闻 发 布 系统 的 主页 面 index.php 的 制作 。index.php 页 面 主要 有 显 








示 最 狐 狐 闻 的 标题 、 加 入 时 间 、 显 示 新 闻 分 类 、 单 击 狐 闻 中 的 分 类 进入 分 类 子 页 面 查 看 新 闻 
等 功能 。 制 作 的 步骤 如 下 。 

(1) 打开 刚刚 创建 的 index.php Ji. WARRE "Bub. DIESE XI" 
一 “保存 ”命令 ， 将 网 页 保存 。 

(2) 用 鼠标 单 击 创建 表格 的 第 1 行 单 元 格 ， 输 入 文字 “新 闻 分 类 ”， 接 下 来 用 “ 绑 定 ” 
标签 ， 将 网 页 所 需要 的 新 闻 分 类 数据 字段 绑 定 到 网 页 中 。index.php 这 个 页 面 使 用 的 数据 表 是 
news 和 newstype， 单 击 “ 应 用 程序 ”面板 中 “ 绑 定 ”标签 上 的 | 则 按钮， 在 弹出 的 菜单 中 选 
择 “ 记 录 集 (查询 )” 选 项 ， 在 该 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 news。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

4) 在 “ 列 ” 栏 中 先 选择 “全 部 ” 单 选 按 钮 。 

完成 的 设置 情况 如 网 5-26 所 示 。 

(3) 绑 定 记录 集 后 ， 将 记录 集 的 相关 字段 插入 全 index.php 网 页 的 适当 位 置 ， 如 图 5-27 
所 示 。 

(4) 由 于 要 在 index.php 这 个 页 面 中 显示 数据 库 中 所 有 新 闻 分 类 的 标题 ， 而 目前 的 设 定 
则 只 会 显示 数据 库 的 第 一 笔 数 据 ， 因 此 需要 加 入 “服务 器 行为 ”中 的 “重复 区 域 ” 的 设置 ， 
选择 {Recordsetl.type_name} 所 在 的 行 ， 如 图 5-28 所 示 。 
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5-26 “记录 集 ” 对 话 框 


TC Apache ht dacsnews\inder. php* =- OX 











5-27 ”将 相应 字段 插入 全 index.php 网 页 中 


(5) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行 为 ” 面 
板 中 的 [ 则 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 重 复 区 域 ” 命 
令 ， 在 打开 的 “重复 区 域 ”对 话 框 中 ， 选 中 “所 有 记录 ， 
单 选 按钮 ， 如 图 $-29 所 示 。 E 5-28 选择 要 里 复 显 未 的 一 列 

(6) 早 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 友 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 























n uo | 记录 


© 所 有 记录 








图 5-29 设置 “重复 区 域 ” 对 话 框 





CI) 除了 显示 网 站 中 所 有 新 闻 分 类 标题 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 分 类 标题 链接 
来 实现 详细 内 容 的 阅读 。 为 了 实现 这 个 功能 ， 首 先 要 选取 编辑 页 面 中 的 新 闻 分 类 标题 字段 ， 
如 图 5-30 所 示 。 


| 
{Recordsetl. type name 





K 5-30 选择 新 闻 分 关 标 题 





(8) 在 “属性 ”向 板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文 件 ” 图 标 ， 在 弹出 的 “ 选 
择 文 件 ” 对 话 框 中 ， 选 择 用 来 显示 评 细 记录 信息 的 页 面 type.php， 设 置 如 网 5-31 所 示 。 
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图 5-31 选择 链接 文件 


(90 以 上 操作 ， 只 会 是 单纯 的 超级 链接 并 有 没 附 市 URL 参数 ， 因 此 要 单 击 “ 参 数 ” 按 
钮 ， 并 设置 超级 链接 要 附 市 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命名 为 id, WE 5-32a 所 
示 ， 在 设置 值 时 ， 单 击 图 5-32b 中 局 标 所 指 问 的 图 标 。 
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图 5-32 “参数 和 动态 数据 ”对 话 框 


(10) 单 击 “ 确 定 ” 投 钮 加 到 编辑 页 面 ， 主 页 面 index.php 中 新 闻 分 类 的 制作 已 经 完成 ， 
最 新 的 新 闻 显 示 页 和 面 设计 效 来 如 网 5-33 所 示 。 
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图 5-33 rh ut cv CR E 


(11) 单 击 “应 用 程序 ”面板 群 组 中 的 “ 绑 定 ”面板 上 的 [由 按 钮 ， 在 弹出 的 菜单 中 选择 
“记录 集 (查询 )” 命 令 ， 在 弹出 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rel 作为 该 记录 和 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news. 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5)“ 排 序 ” 设 置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-34 所 示 。 
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5-34 设置 “记录 集 ” 对 话 框 





(12) 绑 定 “记录 集 ” 后 ， 将 记录 集 的 字段 插入 全 index.php 网 页 的 适当 位 置 。 

(13) 由 于 要 在 index.php 这 个 页 面 显 示 数 据 库 中 部 分 新 闻 的 信息 ， 而 目前 的 设 定 则 只 会 
显示 数据 库 的 第 一 笔 数 据 ， 因 此 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ” 命 令 。 单 
击 选择 index.php 页 面 中 的 最 新 新 闻 标 题记 录 表 格 ， 如 网 5-35 所 示 。 
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[5-35 单 击 选择 最 新 新 闻 标 题记 录 表 格 


(14) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 噩 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 来 单 中 
选择 “重复 区 域 ” 命 令 ， 在 弹出 的 “重复 区域” 对 话 杠 中， 选择 要 重复 的 记录 条 数 〈 例 如 10 
条 )， 如 图 5-36 所 示 。 
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图 5-36 选择 一 次 可 以 显示 的 记录 数 














(150 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 
了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

(160 由 于 最 新 新 闻 这 个 功能 ， 除 了 显示 网 站 中 部 分 
新 闻 外 ， 还 要 提供 访问 者 感 兴趣 的 新 闻 标 题 链接 全 详细 内 
容 来 阅读 ， 首 先 选取 文字 “得 看 ”， 如 图 5-37 HR. 图 5_-37 ”选择 新 闻 标题 “查看 ” 

(17) 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 
击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 
newscontent. php， 设 置 如 图 5-38 所 示 。 
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图 5-38 选择 链接 文件 


(18) 单 击 “ 参 数 ” 投 钮 ， 设 置 超级 链接 要 附 市 的 URL. 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 news id, W| 5-39a 所 示 ， 在 设置 值 的 时 候 ， 单 击 几 5-39b 中 车 标 所 指 回 的 图 标 。 
(19) 单 击 “确定 ” 控 钮 回 到 编辑 页 面 ， 当 记录 集 超过 一 页 ， 束 必须 要 有 “上 一 页 ”、 











pO EELEE 





“下 一 页 ”每 按钮 或 文学 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 束 是 “记录 集 导 航 条 ”的 功能 。 
“记录 集 导 航 条 ”按钮 位 于 “ 捅 入 ”工具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 “名 
用 ”切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 导航 条 ” [可 工具 按钮 ， 如 图 5-40 所 示 。 
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图 5-39 “参数 ”和 “动态 数据 ”对 话 框 
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图 5-40 ”选择 “记录 集 导航 条 ” 


(200 在 打开 的 “记录 和 集 导 航 条 ”对 话 框 中 ， 选 取 要 导航 条 的 记录 集 Rel 以 及 导航 条 的 
显示 方式 “文本 ”， 如 网 5-41a 所 示 。 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 
现 该 记录 集 的 导航 条 ， 如 网 5-41b 所 示 。 

21) 如 果 和 希望 看 到 总 共有 多 少 记录 ， 当 前 记录 是 第 几 条 ， 那 么 必须 插入 “记录 集 导 航 
Jus". 在 “插入 ”工具 栏 的 “数据 ”类 型 中 ， 单 击 “ 显 示 记 录 计 数 ” 工 具 按钮 出 ， 在 弹出 
的 快捷 菜单 中 ， 选 取 要 导航 状态 的 记录 集 为 Rel， 如 图 5-42a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 
回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-42b 所 示 。 
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(22) index.php 这 个 页 面 需 要 加 入 “查询 ”的 功能 ， 这 样 新 闻 发 布 系统 才 不 会 因 日 后 数 
据 太 多 而 有 人 不易 访问 的 情形 发 生 ， 设 计 如 图 5-43 所 示 。 


二 :| — 1 1 11 [£8 S 


图 5-43 ”查询 主题 设计 








重点 提示 : 利用 表单 及 相关 的 表单 组 件 来 制作 利用 关键 词 查询 数据 的 功能 ， 需 要 注意 如 
TRE, 

1) 图 5-43 所 示 的 内 容 都 在 一 个 表单 之 中 。 

2 )“ 查 询 主题 ”后 面 的 文本 框 的 命名 为 keyword. 

3 )“ 查 询 ”按钮 为 一 个 提交 表单 按钮 。 








(23) 在 此 要 将 之 前 建立 的 记录 集 Rel 做 一 下 更 改 ， 打 开 “ 记 录 集 ” 对 话 框 ， 并 进入 
“高 级 ”设置 ， 在 原 有 的 SQL 语法 中 ， 加 入 一 段 查询 功能 的 语法 ; 





where news, title like '?6".S key word."906' 


那么 ， 以 前 的 SQL 语句 将 变 成 如 图 5-44 所 示 。 


和 名称: mM 
连接 aus 


SUL: SELECT * 
FROM news 
WHERE news title like 'X". keyword. "& 
ORDER BY mews id DESC 


表格 ERE SOL: 
R a 
d. ”预存 过 程 


WHERE 


ORDER. BT 





图 5-44 修改 SQL 语句 


重点 提示 : 其 中 like 是 模糊 查询 的 运算 子 ，% 表 示 任 意 字符 ， 而 keyword 是 个 变量 ， 分 
别 代表 关键 词 。 





(240 切换 到 代码 设计 窗口 ， 找 到 Rel 记录 集 相 应 的 代码 并 加 入 代码 : 


$keyword-$ POST[keyword]; /定义 keyword 为 表单 中 "keyword" 的 请 求 变 量 ， 如 网 5-45 
所 示 ， 完成 设置 。 
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(25) 以 上 的 设置 





<?php require once('Connections/news.php'): 


;ievword-s ' [5 ;ievworc H 
if (!function exists("GetSQLValueString")) { 
function GetSQüLValueString($theValue, $theType, $theDefinedValue = "", $theNotDefinedValue = "" 
{ 
if (PHP VERSION < 6) { 
$theValue = get magic quotes gpcí() ? stripslashes($theValue) : $theValue; 
} 


$theValue = function existsí("mysql real escape string") ? mysql real escape string($theValue) : 


mysql escape string($theValue); 


switch ($theType) { 

case "text": 
$theValue = ($theValue !- "") ? "'" , $theValue . "'" ; 7 
break; 

case "long": 

case "int": 
$theValue = ($theValue !- ""j ? intval($theValue) : 
break; 

case "double": 
$theValue = ($theValue !- "") ? doubleval($theValue) : " 
break; 


5-45 ”加 入 代码 
完成 后 ，index.php 系统 主页 和 面 束 有 查询 功 能 了 ， 先 在 数据 库 中 加 入 两 





条 新 闻 数 据 ， 可 以 按 下 《F12〉 键 至 浏览 右 测 试 一 下 是 否 能 正确 地 查询 。 首 先 index.php 页 面 
全 显示 所 有 网 站 中 的 新 闻 分 类 主题 和 最 新 新 闻 标题 ， 如 图 5_46 所 示 ， 
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5-46 ”主页 面 浏览 效果 


(260 然后 在 关键 词 中 输入 “测试 ”并 单 击 “ 合 询 ”按钮 ， 结 来 会 发 现 页 面 中 的 记录 
只 显示 “测试 ”所 发 表 的 最 新 新 闻 主 题 而 已 ， 这 样 得 询 功 能 就 已 经 完成 了 ， 效 果 如 图 5-47 


Bia. 
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图 5-47  JUTAEUHAICR 


5 狐 闻 分 类 页 面 设 计 


狐 闻 分 类 页 面 type.php 用 于 显示 每 个 新 闻 分 类 的 页 面 ， 当 访问 者 单 击 index.php 页 面 中 
的 任何 一 个 新 闻 分 类 标题 时 就 会 打开 相应 的 新 闻 分 类 页 面 ， 新 闻 分 类 页 面 设计 效果 如 图 5-48 
所 示 。 
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图 5-48 新 闻 分 关 页 面 效果 


详细 的 操作 步骤 说 明 如 下 。 

(10 执行 染 单 “文件 ”一 “ 痢 建 ”命令 创建 新 页 向 ， 和 输入 网 页 标题 “新 闻 分 关 ”， 执 行 
菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 将 该 文档 保存 为 type.php。 

(2) 新 闻 分 类 页 面 和 首页 面 中 的 议 态 页 面 设计 差不多 ， 在 此 不 做 证 细 说 明 。 

(3) type.php 这 个 页 面 主要 是 显示 所 有 新 闻 分 类 标题 的 数据 ， 所 使 用 的 数据 表 是 news, 
















单 击 “ 绑 定 ”面板 中 的 “增加 ”上 的 图 按钮 ， 在 弹出 的 菜 音 中， 选择“ 记录 集 〈 碍 询 )” 选 





项 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 


1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 
2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连接 对 象 news. 
3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 


4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮。 


选 ” 的 条 件 为 : news_id=URL 参数 : id. 


“排序 ”方法 为 以 news_id 升序 。 


再 单 击 “确定 ”按钮 后 ， 束 完成 设 定 了 ， 如 图 5-49 所 示 。 


名 和 i 
| 
eh. 


x (9 全 部 O 选 定 的 : 


ME: pesia | E ~ 
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5-49 ”设置 “记录 和 集 ” 对 话 框 


(4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬入 至 type.php 网 页 中 的 适当 位 置 ， 如 图 5-50 


四 C: XApachekht docsknewsstrzpe. php* 


le? Ctr? «td» table? Ctr? td? table? Ctr) td? table? Ctr) 4&d 








| 
> [RI Q [00% vlTT2 x 441» 52 K / 2 秒 | Unicode 


5-50 ”记录 集 字 段 插入 至 type.php 网 页 中 





pO EELEE 








(50 为 了 显示 所 有 记录 ， 需 要 加 入 “服务 器 行为 ”面板 中 的 “重复 区 域 ”命令 。 单 击 
type.php 页 面 中 需要 重复 的 表格 ， 如 图 5-51 Joa. 


10095 (511) = 
8096 (408) = 


2036 (102) = — | D 
TE 2 
图 5-51 单 击 选 择 要 重复 显示 的 表格 


(6) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 内 按钮 ， 在 弹出 的 染 单 
H, WFE EEK” ME, 打开“ 重复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 ， 如 
图 5-52 所 示 。 

















: hd 


Mp 7T5 © 10 记录 
O 





所 有 记录 








K|5-52 ”选择 一 次 可 以 显示 的 记录 数 


CI) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

(8) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 币 副 工具 按钮 ， 打 开 “ 记 录 和 集 导 航 条 ”对 话 框 ， 
在 打开 的 对 话 框 中 ， 选 取 Recordsetl 记录 集 以 及 导航 条 的 显示 方式 为 “文本 ”如 网 5-53a 所 
示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 网 5-53b 
PI. 























ix E 
EDAR © y 
O mg 








Ea 


新 闻 标 题 (Recordsetl news title} Pine | 


—l 




















b) 
图 5-53 添加 “记录 集 导 航 条 ” 





(9) 在 “插入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 草 工 具 按钮 ， 在 弹出 的 菜单 中 ， 选 取 要 导航 
状态 的 记录 集 为 Recordset1， 如 图 5-54a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 
现 页 面 出 现 该 记录 集 的 导航 状态 ， 如 图 5-54b 所 示 。 
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记录 集 导 航 状 态 





WRR: [Recordset! v 
ebd 记录 1 到 5 (总 共 10 个 记录 








T C: XÀpachexht docsknewsktrzpe. php* 





i 记录 {Recordsetl FirstRecord) 到 | (Recordsetl LastRecord) (总 共 (Recordset! TotalRecords) ) 





~ € 
新 闻 标 题 : (Recordsetl news title] 洋 曙 内 容 


< ili 
<body> <table> Ctr? <td> <table> Ctr? <td> <table> <tr> <td> (RI AQ 100% v|TT2 x 441v 58 K / 2 fb Unicode (UTF-B) — 








图 5-54 添加 “记录 集 导 航 状 态 ” 
C100 选取 文字 “详细 内 容 ” 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文 
件 ” 图 标 ， 在 弹出 的 “选择 文件 ”对 话 杠 中， 选择 用 来 显示 详细 记录 信息 的 页 面 
newscontent.php， 设 置 如 图 5-55 所 示 。 


站 点 和 服务 器 ... 


选择 文件 名 自 : @) 文件 系统 站 点 根 目录 
O 320818 








ERGE): | CJ mens «Oodd 








(C3. mmServerScripts 75 index. php 
(3. notes dq» 

(Cj admin * type. php 
Connections 


O data 


newscontent. php 


O images 














WA N): newscontent. php 
FEW (T): PAX (3) v 


URL: newscontent. php 
相对 于 : $5 w| index. php 
在 站 点 定 尺 中 更 改 默 认 的 链接 相对 于 




















5-55 ”选择 链接 文件 


Jt 全 


(11) 单 击 “参数 ”按钮 ， 设 置 超级 链接 要 附带 的 URL. 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 news id, "Kl 5-56a 所 示 ， 在 设置 值 的 时 候 单 击 图 5-56b P EITI IRL HER 











FP. ERS AN E FOEN pou GEELES TE 


域 : 日 e 记录 集 (Recordzetl) 
: 多 type_id 


i e 
(+) ©) news_content 
名 称 3 : news date 


news id news author 





























帮助 OD :|€?php echo $row Rel['news id']; * 











5-56 “参数 ”和 “动态 数据 ”对 话 框 
(120. 加 入 显示 区 域 的 设 定 。 衣 先 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 网 5-57 所 示 。 


记录 {Recordsetl_first} 到 {Recordsetl_ last] (总 共 [Recordsetl total] ) 





5-57 ”选择 要 显示 的 表格 


d3) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 染 单 
中 ， 选 择 “ 显 示 区 域 / 如 果 记 录 集 不 为 空 则 显示 区 域 ” 命 令 ， 打 开 “ 如 果 记 录 集 不 为 空 则 显 
示 区 域 ” 对 话 框 。 在 “记录 集 ” 中 选择 Recordsetl, An] 5-58a 所 示 ， 青 单 击 “确定 ”按钮 
回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显 
示 ” 的 灰色 卷 标 ， 这 表示 已 经 完成 设置 ， 如 图 5-58b 所 示 。 








MI ICOK SEA 29 7B ER 











A CCusacheMatdoes Ver trpe. phos 





1 


à 
Í 记录 (Reconiset! Fustkecord] D) (Recosdest! Laetiaecosd) (E (Recordert! TotalRaconie}) 
BD 


| 




















.- 
Bebo Hesse Henn Medo DSL [V] Q o-oo ws w/e vie nr | 
b) 


5-58 “记录 集 不 为 裤 ” 则 显示 












7PHP-^ 








C14) 输入 “对 不 起 ， 此 新 闻 分 类 中 没有 任何 新 闻 ” 说 明文 字 ， 同 时 选取 记录 集 没 有 数 
据 时 要 显示 的 数据 表格 ， 如 图 5-59 所 示 。 











5-59 ”选择 没有 数据 时 显示 的 区 域 


(155 单 击 “应 用 程序 ”和 面板 群 组 中 的 “服务 器 行为 ”和 面板 上 的 加 按钮 ， 在 弹出 的 末 早 
中 ， 选 择 “ 显 示 区 域 / 如果 记 录 集 为 空 则 显示 区 域 ” 人 命令， 在 “记录 集 ” 中 选择 
Recordset1， 如 图 5-60a 所 示 ， 再 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显 
示 的 区 域 左 上 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 着 标 ， 这 表示 已 经 完成 设置 ， 
效果 如 图 5-60b 所 示 。 














MIA OK SED 7p B ER 








Recordsetl v 











T) C: \Apachethtdocsinewsitype. php* -0x 


VR menm Fie and} 到 Tea id Tatius (总共 theca EL Te Ra ) 





E (Recordsetl news title] 








-a PRE ir ir BEE BIG co010-20 - s 
<body> <table> <tr> <td> k] Q 1008 4/819 x 455v 60 K / 2 fU Unicode (UTF-8) 


b) 
图 5-60 “记录 集 为 空 ” 则 显示 


到 这 里 ， 新 闻 分 类 页 面 type.php 的 设计 与 制作 就 已 经 完 

















新 闻 内 容 页 面 newscontentphp 用 于 显示 每 一 条 新 闻 的 详细 内 容 ， 这 个 页 面 设计 的 重点 





在 于 如 何 接收 主页 面 index.php 和 type.php 所 传递 过 来 的 参数 ， 并 根据 这 个 参数 显示 数据 库 
中 相应 的 数据 。 新 闻 内 容 页面 的 页 面 设计 效果 如 网 5-61 所 示 。 

详细 操作 步骤 如 下 。 

(1) 执行 荣 单 “ 文 件 ” 一 “新 建 ” 命 令 ， 创 建新 页 面 ， 执 行 荣 单 “ 文 件 ” 一 “保存 ” 命 
令 ， 在 站 点 中 news 文件 来 中 将 该 文档 保存 为 newscontent.php. 
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AIT IB] A Tp Zi St 7T Ax 


A http://127. 0.0. 1/news/newscontent.php?news id-2 — Microsoft Internet Explorer 
THF AmE EE) KEA IAM 帮助 0 m | Ld 


ORE- O- iac s «wx e O- 3» )-« NN 
"m (p) Es //121. 0. 0. 1/news/newscontent. php?news id-2 < 输入 关键 词 搜索 p? vi g SEE 链接 Quac E 














NEWS 
PHP 新 闻 系 统 


最 新 新 闻 司 学 录 EKE 网 络 开 发 个 人 简介 


新 闻 标 题 : 网 站 开通 了 加 六 时 间 : 2011-07-10 
新 闻 内 容 : 网 站 开通 了 ， 欢迎 访问 


北京 环 博识 化 版 权 所 有 S2010-2011 


ý | * Internet 





























图 5-61 新闻 内 容 页 面 设计 效果 图 
(2) 页 面 设计 和 前 面 的 页 面 设计 差不多 ， 效 果 如 图 5-62 所 示 。 


T C: \Apache\ht docs&news*newscont ent. php = x 


PHP 新 闻 系 统 


768 v 


北京 环 博识 化 版 权 所 有 e010-201 


Mw 
| E 
dy? <table> <tr> <td> <table> <tr> <td> <table> <tr> <td> <table> «e> «D [ES 819 x 479v 49 K / 2# Unicode (UTF-B) — . 








图 5-62 新闻 内 容 页 面 设 计 


(3) 单 击 “ 绑 定 ” 面 板 中 的 “增加 ”上 的 外 按 钮 ， 在 弹出 的 菜单 中 选择 “记录 集 〈 得 
询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 Recordsetl 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 news。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 news。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5) 设置 “筛选 ”的 条 件 为 : news_id =URL 参数 : news id. 

再 单 击 “ 人 确定” 按钮 完成 设 定 ， 如 图 5-63 所 示 。 
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名 称 : hecaordzetl 


es. 


xj 9 全 部 O 选 定 的 : 


newz id 

news title 
news lyvpe 
news content 
news date 





5-63 ”设置 “记录 集 ” 对 话 框 


(4) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬入 至 newscontentphp 页 面 中 的 适当 位 置 ， 这 样 
束 完 成 了 新闻 内 容 页 耐 newscontent.php 的 设置 ， 如 图 5-64 PTR. 





中 | C:\Apache\htdocs\news\newscontent. php* = me: 


HEIRED news. php 


NEWS 
PHP 新 闻 系 统 


JERIH LEBER BIB 62010-2011 


的 
< T d 
dy? <table> <tr> <td> <table> Ctr? <td> <table> <tr> <td> <table> <tr> <td> (R) $9 Q 100% 4/819 x 455v 51 K / 2 f? Unicode (UTF-8) — - 





5-64 ”将 相应 子 段 插入 全 新 闻 内 容 页 和 面 





ERE HEN HiT 


3r E Acn AR d GBIISONT AARE, qu pas a aA ERIR T 
闻 内 容 和 新 闻 的 类 型 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 登 录 系 统管 理 入 口 页 面 的 设 
计 效 果 如 图 5-65 所 示 。 

















新 闻 发 布 系统 开发 





T5 C: A pachekhtdoesknewskadnintadmin login. php eX 
新 闻 后 台 管 理 中 心 
NE o 


FE Fu 
密码 [D | | 





100% — 4 4863 x Z1Te 1 K/ 1 P Unicode (b - 


5-65 系统 管理 入 口 页 面 


随员 管理 入 口 页 面 


后 侣 管理 主页 面 必 须 受 到 权限 管理 ， 可 以 利用 登录 账号 与 密码 判别 是 否 为 有 效用 户 来 实 
现 权 限 的 设置 管理 。 

详细 操作 步骤 如 下 。 

(1) 执行 业 单 “文件 ”一 “新 建 ” 命 令 ， 创 建新 页 面 ， 输 入 网 页 标题 “管理 员 登 录 ”， 
执行 菜单 “文件 ”一 “保存 ”命令 ， 在 站 点 news 文件 夹 中 的 admin 文件 夹 中 将 该 文档 保存 
为 admin_login.php。 

(2) 执行 菜单 “插入 记录 ”一 “表单 ”一 “表单 ”命令 ， 插 入 一 个 表单 。 

(3) 将 光标 放置 在 该 表单 中 ， 执 行 染 单 “ 插 入 记录 ”一 “表格 ”命令 ， 打 开 “ 表 格 ” 对 
话 框 ， 在 “ 行 数 ”文本 框 中 ， 输 入 需要 插入 表格 的 行 数 4。 在 “ 列 数 ” 文 本 框 中 ， 输 入 需要 
插入 表格 的 列 数 2。 在 “表格 宽度 ”文本 框 中 ， 输 入 400 像素 ， 其 他 参数 保持 默认 值 ， 如 
图 5-66 所 示 。 





























行 数 5: 
表格 宽度 : ES 
边框 粗细 : [0 ER 
单元 格 边 距 : [0 | 
单元 格 间距 : 0 B 


辅助 功能 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 


WE | 
i 
5-66 设置 “表格 ”对 话 框 参数 
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(4) 单 击 “ 人 确定” 按钮 ， 在 该 表单 中 插入 了 一 个 4 行 2 列 的 表格 ， 选 择 表格 在 “属性 ” 
面板 中 ， 设 置 “ 对 齐 方式 ”为 “居中 对 齐 ”。 拖 动 鼠 标 选 择 第 1 行 表 格 所 有 单元 格 ， 在 “ 属 
性 ”面板 中 单 击 国 按钮 ， 将 第 1 行 表格 合并 。 用 同样 的 方法 把 第 4 行 合 并 。 

(5) 在 该 表单 中 的 第 1 行 中 输入 文字 “新 闻 后 台 管 理 中 心 ”” 在 表格 的 第 2 行 第 1 个 单 
元 格 中 输入 文字 说 明 “ 账 号 :” 在 第 2 行 表格 的 第 2 个 单元 格 中 单 击 “ 文 本 域 ” 按 钮 回 ， 插 
入 单行 文本 域 表 单 对 象 ， 定 义 文本 域名 为 username。“ 文 本 域 ” 属 性 设置 如 图 5-67 所 示 。 














属性 
O 如 本 域 字符 宽度 | | 类 型 Ofe Osa OET BOX v 
RETHER| | 初始 仁和 IJ | | 多 
SA Q9 
[]Ri& G) 


5-67 username“ 文 本 域 ” 的 属性 设置 
(6) 在 第 3 列表 格 的 第 1 个 单元 格 中 ， 输 入 文字 说 明 “ 密 码 :”， 在 第 3 列表 格 的 第 2 个 
单元 格 中 单 击 “文本 域 ” 投 钮 回 ， 插 入 单行 文本 域 表 单 对 象 ， 定 义 文 本 域名 为 password. 
“文本 域 ” 属 性 设置 如 网 5-68 所 示 。 














属性 
p xe 字符 宽度 om) | | 类 型 〇 单行 6) Osam OBP 类 中 无 ~ 
最 多 字符 数 | | 初始 值 D |] 
OSA M) 
[]Ri& R) 


5-68 password“ 文 本 域 ” 的 设置 
CI) 单 击 选择 第 4 行 蛙 元 格 ， 执 行 两 次 亲 单 “插入 记录 ”一 “表单 ”一 “ 投 钮 ”命令 ， 
插入 两 个 按钮 ， 并 分 别 在 “属性 ”面板 中 进行 属性 变更 ， 一 个 为 登录 时 用 的 “提交 表单 ” 选 
项 ， 夯 一 个 为 “ 重 设 表单 ”选项 ， 其 属性 设置 及 效果 如 图 5-69a、b、c 所 示 。 








属性 
按钮 名 称 值 on 动作 G@) 提交 表单 6) OFM 2$ (C) 
人 〇 重 设 表单 M 
a) 
属性 
| zd Ev) 动作 〇 提交 表单 6) OFW aS (C) 
GO 重 设 表单 M) 
b) 


TIAA A EIEH G 
PaT | 


E 8 ooo | 





c) 
图 5-69 设置 按钮 名 称 的 属性 及 效果 
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(8) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ”面板 上 的 因 按 钮 ， 在 弹出 的 菜单 
中 选择 “用 户 身份 验证 /登录 用 户 ”命令 ， 打 开 “ 登 录用 户 ”对 话 框 ， 设 置 为 如 果 不 成 功 将 
返回 主页 面 index.php， 如 果 成 功 将 登录 后 台 管理 主页 面 admin.php， 如 图 5-70 所 示 。 























从 表单 获 职 输入 : [formi 区 ` 
用 户 名 字段 : username 
密友 字段: p assword 














使 用 连接 验证 : news 

表格 : | admin 
用 户 名 列 : username 
密码 列 : | password 






































如 果 登 录 成 功 ， 转 到 |: admin. php pls... 


[] 转 到 前 一 个 URL 如 果 它 存在 ) 
如 果 登 录 失 败 ， 转 到 : | . . /index. php pls... 

















基于 以 下 项 限制 访问 : © 用 户 名 和 密码 
〇 有 ”用户 名 、 密 码 和 访问 级 别 
获取 级别 自 : ;1 








图 5-70 设置 “登录 用 户 ” 对 话 框 


(9) 执行 荣 单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 。 单 击 “ 行 为 ”面板 中 的 外 
按钮 ， 在 弹出 的 菜 蛙 中， 选择 “检查 表单 ”命令 。 打 开 “ 检 查 表 单 ” 对 话 框 ， 设 置 username 
和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”， “可 接受 ”为 “任何 东西 ”如 图 5-71 所 示 。 


input "username" (R) | 
input "password" (R) 
域 : 


值 : 必需 的 








可 接受 : ”任何 东西 O 数字 
O 电子 邮件 地 址 〇 数字 从 “| 到 | | 





图 5-71 “检查 表单 ”对 话 框 





单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 完 成 后 台 管 理 入 口 页 面 admin_login.php 的 设计 与 
制作 。 














百人 台 管 理 主页 面 是 管理 员 在 登录 页 面 验证 成 功 后 所 登录 的 页 面 ， 这 个 页 面 可 以 实现 新 








增 、 修 改 或 删除 新 闻 内 容 和 新 闻 分 类 的 内 容 ， 使 网 站 能 随时 保持 最 新 、 最 实时 的 信息 。 页 面 
结构 如 图 5-72 所 示 。 








A 管理 主页 面 -~ Nicroso ft Internet Explorer DAR) 
WFT 编辑 外 ) SEV 收藏 由) IAM 和 帮助 0) a 


QmB- Ot» Js ux e 2-54 
地 址 0) E] http: //127.0.0. 1/news/adnin/adnin. php < 输入 关键 词 搜索 MERA dum Qe: E 
ry B " 


(CE WS 








L4 


PHP 新 闻 系 统 


最 新 新 闻 同学 录 图 片上 传 


新 闻 后 台 管理 中 心 ; : HESI HPR] 
添加 新 闻 

添加 新 闻 分 类 

管理 员 你 好 ?请 你 管理 新 闻 分 类 ， 

类 型 管 理 

国际 新 闻 [EE] HRR] 


北京 环 二 次 化 版 可 所 有 2010-2011 





5-72. 后 台 管 理 主 页 面 效 果 图 





详细 操作 步骤 如 下 。 

(1) 打开 admin.php 页 面 ,，( 此 页 面 设计 比较 简单 ， 页 面 设计 在 此 不 做 说 明 )， 单 击 “ 绑 
定 ” 面 板 上 的 [按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 在 “记录 和 集 ”对 话 
框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Re 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连 接 对 象 news. 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 news。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5)“ 排 序 ” 设 置 为 news_id 降序 方式 。 

完成 的 设置 情况 如 图 5-73 所 示 。 











am: 
表格 


xp (9 mo O 选 定 的 : 


p 
s 





5-73 ”设置 “记录 集 ” 对 话 杠 











- 


第 5 音 CIEZEUDLLE: 








(2) 绑 定 记录 集 后 ， 将 Re 记录 集中 的 news title 字段 插入 全 admin.php 网 页 中 的 适当 位 
置 ， 如 图 5-74 所 示 。 
E] C: hpachevht docs\news\admin\admin. php* SE 
p 新 闻 系 统 A. ii 





10096 (430) 
7096 (342) | — — — — —— — — — — —4—— ———— 30896 (147) 
RS Qu uiro dir Sfi EPIS SEES 


北京 环 博 文化 版 权 所 有 ez2010-2011 
vj 
< Ill | > 
d> <table> <tr> <td> <table> <tr> <td> <table> <tr> <td> [k |$) Q lo0% — 4|TI15 x 417v 53 K / 2 $ Unicode (UTF-8) 








5-74 记录 集 的 字段 插入 至 admin.php 网 页 中 


(3) 由 于 要 加 入 “重复 区 域 ”命令 ， 所 以 首先 选择 需要 重复 的 表格 ， 如 图 5-75 所 示 。 








5-75 ”选择 重复 的 表格 


(4) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 喜 行 为 ”面板 上 的 四 按钮 ， 在 弹出 的 深 单 
F, A ERKE” MS, 打开“ 重复 区 域 ” 对 话 框 ， 设 定 一 页 显示 的 数据 为 10 条 记 
录 ， 如 图 5-76 所 示 。 








5-76 选择 记录 集 显 示 的 记录 数 





(5) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

(6) 在 “搬入 ” 栏 的 “数据 ”类 型 中 ， 单 击 | 副 工具 按钮 打开 “记录 集 导 航 条 ”对 话 框 ， 
选取 Re 记录 集 以 及 导航 条 的 显示 方式 ， 如 图 5-77a 所 示 ， 然 后 单 击 “ 确 定 ” 按 钮 回 到 编辑 
页 面 ， 会 发 现 页 面 出 现 该 记录 和 集 的 导航 条 ， 如 图 5-77b Hrs. 
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10096 (768) 

















|< 





| | > 
<body> <table> <tr> <td> <table> <tr> <td>|<table’™ [ki q 100% ~|T15 x 417w 5T K / 2 f? Unicode (UTF-8) 


b) 
图 5-77 添加 “记录 集 导航 条 ” 

















(7) admin.php 是 提供 省 理 员 链 接 公 新闻 编 辑 的 页 面 ， 然 后 进行 新 增 、 修 改 与 删除 等 操 
作 。 设 置 了 4 个 链接 ， 各 链接 的 设置 如 表 5-7 Bron 


d 5-7  admin.php 页 面 的 链接 设置 


名 称 链接 页 面 
标题 字段 {re_news_title} newscontent.php 
添加 新 闻 news_add.php 

修改 news upd.php 

删除 news del.php 


重点 说 明 : 其 中 “标题 字段 fre_news titlej”、“ 修 改 ” 及 “删除 ”的 链接 必须 要 传递 参 
数 给 转 到 的 页 面 ， 这 样 转 到 的 页 面 才 能 够 根据 参数 值 而 从 数据 库 将 某 一 笔 数 据 筛 选 出 来 再 进 
行 编辑 。 

(8) 首先 选取 “添加 新 闻 ”， 在 “属性 ”面板 中 将 它 链 接 到 admin 文件 夹 中 的 news. add. 


php Jil. 

(9) 选取 右边 栏 中 的 “修改 ”文字 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 
news upd.php, ix Ell 5-78 所 示 。 





新 闻 发 布 条 统 开发 


站 点 根 目录 


E 
«| Od em 


选择 文件 名 自 : GO 文件 系统 
〇 数据 源 





查找 范围 I: O admin 


(C3. notes ^5 type add. php 
Kl admin. php 75 type del.php 
Kl admin login. php 75 type upd.php 
ic news add.php 
new s_del. php 











news_upd. php 











文件 名 OD: 
文件 类 型 CD: 


news_upd. php 


所 有 文件 ex) 

















URL: | news_upd. php 
相对 于 : PES v 
在 站 点 定 必 中 更 改 默 认 的 链接 相对 于 





admin. php 





5-78 选择 链接 文件 


(100 单 击 “ 参 数 ” 控 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 news_id， 如 图 5-79a 所 示 。 在 设置 值 的 时 候 单 击 图 5-79b 中 孔 标 所 指 问 的 图 标 。 


C= 
取消 
ET 


news title 
news type 
news content 
news date 
news author 


(i= 
ELM 


news id 








v 




















: <?php echo $row Re['news id ]; ?. 











b) 
“参数 ”和 “动态 数据 ”对 话 杠 





5-79 


(11) 选取 “删除 ”文子 并 重复 上 面 的 操作 ， 要 转 到 的 页 面 改 为 news_del.php， 并 传递 


新 闻 标 题 的 ID 参数 ， 如 图 5-80 所 示 。 


站 点 根 目录 


站 点 和 服务 器 ... 


选择 文件 名 自 : GO 文件 系统 
O eis 
Q 2 p 








查找 范围 0): | C) ainin Y 








.notes 
司 adnin. php 





*5 admin login. php *5 type upd. php 
^ news add.php 
geil news_del. php 


gil news_upd. php 


*5 type add. php 
*5 type del.php 








Xt: 
文件 类 型 (T): 


URL: 





news_del. php 


PRATILI x) m 




















news del.php?news id-X?php echo $row Re[' 








相对 于 : 


wrt v| admin. php 


在 站 点 定义 中 更 改 默 认 的 链接 相对 于 





5-80 ”设置 传递 全 news_del.php 









PHP+ QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





(12) 再 选取 标题 字段 {Re_news_title} 并 重复 上 面 的 操作 ， 要 前 往 的 细 贡 页 面 改 为 
newscontent.php， 并 传递 狐 闻 参数 ， 如 图 5-81 Br. 


选择 文件 名 自 : (Gres iS AB HE 


Cines wh cesa... 


sHHED[Os — Morem 


index. php 


i  mmserverscripts 
(Cj nates ynewscontent. php 
[C admin d| type. php 
[jCennecti ons 


ic data 


[Cj images 


T 
T 


URL: ..fnewscontent.php?news id-Z?php echo fr: 


相对 于 : FE ** | admin. php 
£p Sh e xE S P ECEABAT 











图 5-81 设置 传递 全 newscontent.php 


(13) 单 击 “ 确 定 ” 按 钮 ， 完 成 转 到 详细 页 面 的 设置 。 人 至 此 ， 已 经 完成 了 新 闻 内 容 的 编 
辑 ， 现 在 来 设置 一 下 新 闻 分 类 。 单 击 “ 绑 定 ” 面 板 上 的 办 按钮， 在 弹出 的 肖 音 中， 选择 “ 记 
录 集 (查询 )” 命 令 ， 在 “记录 和 集 ”对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rel 作为 该 记录 集 的 名 称 

2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 news。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 newstype。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 5-82 所 示 。 





























x: © E O 选 定 的 : 


we. — 
v. x Mu 





图 5-82 设置 “记录 和 集 ” 对 话 框 











新 闻 发 布 系统 开发 





(14) 绑 定 记录 集 后 ， 请 将 Rel 记录 集中 的 type name 字段 插入 至 admin.php 网 页 中 的 


bc C: NApachekht docs*news*admin admin. php 2 EIX 


€T news. php 
: PAPE 
H ` 


个 人 简介 


: 

: 

yp nare) M [ER] DR] o: 
: 3 

z ^ 

2 ^ 


JEREBMSX hit? PR 2010-2011 


Y 
< i | E 
d> table? <tr> <td> <table> <tr> <td> <table> <tr> <td> [R | Q 1008 vv T15 x 417v 59 K / 2 f^ Unicode (UIF-8) — - 





5-83 ”插入 相应 字段 至 admin.php 网 页 中 


(150. WMA “RERAN” P ERK” ME, Debes WME 5-84 Bp. 





图 5-84 选择 要 重复 的 表格 


(160 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 载 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 沈 单 
中 ， 和 选择“ 重复 区 域 ” 命 令 ， 打开 “重复 区 域 ”对 话 框 ， 设 定 一 页 显示 的 数据 为 “所 有 记 
3x", 如 图 5-85 所 示 。 





us 


所 有 记录 


EE 
Tue . 


Ó 
© 





5-85 ”设置 “重复 区 域 ” 对 话 框 


C17) 单 击 “确定 ”按钮 问 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 重复 的 区 域 堪 上 角 出 现 了 
一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

(180 首先 选取 左边 栏 中 的 “修改 ”文字 ， 选 择 admin 文件 夹 中 的 type upd.php 链接 并 
传递 type id 参数 ， 如 图 5-86 Pros. 























f PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


选择 文件 名 自 : Orta ENS a 


ERIE: [Osmin — à303à3032 vor 








(C3. notes T] type add. php 
gc admin. php Tl type_del. php 


admin login. php 75 type upd. php 


J news_add. php 
dJ news_del. php 
T news_upd. php 


xi 0n 
TFN QT: PPAT Oe) v 


URL: type upd.php?type id-Z?"php echo $row Rel 


相对 于 : FE **| admin.php 
TE E S P BETERLABSgEROEECHET- 








图 5-86 设置 传递 全 type_upd.php 


(19) 选取 “删除 ”文字 并 重复 上 面 的 操作 ， 要 前 往 的 细节 页 面 改 为 type_del.php， 并 传 
递 type id 参数 ， 如 图 5-87 所 示 。 


选择 立 件 名 自 ; OTHERS IS SEHR 
DEAE 


seto: Das ë x OP 
(C3. notes "type add. php 
T] admin. php dJi type_del. php 

地 | admimr login. php Mhl type_upd. php 

dJ news_add. php 

d news_del. php 


D news_upd. php 


me 
TFN T): PPAT i.) v 


URL: type del.php?type id php echo $row Rel 


相对 于 : Arg **| admin. php 
TEX mE M p EAA EAT 








图 5-87 设置 传递 全 type_del.php 





(200 再 选取 “添加 新 闻 分 类 ”， 在 “属性 ”面板 中 将 它 链接 到 admin 文件 夹 中 的 type_ 
add.php 页 面 。 

OD 后 台 管理 页 面 是 管理 员 在 后 台 管理 入 口 页 面 admin, login.php 输入 正确 的 账号 和 密 
码 才 可 以 进入 的 一 个 页 面 ， 所 以 必须 设置 限制 对 本 页 的 访问 功能 。 单 击 “ 应 用 程序 ”面板 群 
组 中 “服务 器 行为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “用 户 吴 份 验证 /限制 对 页 的 
访问 ”选项 ， 选 择 “ 限 制 对 页 的 访问 ”命令 ， 如 图 5-88 Pr. 
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图 5-88 ”选择 “限制 对 页 的 访问 ”命令 


(22) 在 打开 的 “限制 对 页 的 访问 ”对 话 框 中 的 “基于 以 下 内 容 进 行 限制 ”选择 “用 户 
名 和 和 密码” 如 来 访问 锌 拒绝 ， 则 转 到 首页 index.php, WE 5-89 所 示 。 


基于 以 下 内 容 进行 限制 : © ”用户 名 和 密码 
O ”用户 名 、 密 码 和 访问 级 别 
选 职级 别 : 











如 果 访问 被 拒绝 ， 则 转 到 : |.. /index. php 

















图 5-89 设置 “限制 对 页 的 访问 ”对 话 框 
单 击 “ 人 确定” 按钮 ， 束 完成 了 后 台 管 理 主页 面 admin.php 的 制作 。 











狐 增 新 闻 页 面 news add.php 设计 的 页 面 效果 如 图 5-90 所 示 ， 主 要 是 实现 插入 新 闻 的 
功能 。 详 细 操 作 步 骤 如 下 。 


(1) 创建 news add.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 国 按 钮 ， 在 弹出 的 菜单 中 ， 选 








择 “ 记 录 集 《得 询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 进行 如 图 5-91 所 示 的 设 管 。 

(2) 绑 定 记录 集 后 ， 单 击 “ 痢 闻 分 关 ” 的 列表 菜单 ， 在 “新 闻 分 类” 的 列表 沫 单 属 性 面 
Bop, Habe as. 按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 进行 相关 设置 ， 如 图 5-92 
所 示 。 









PHP 


T C: XApachehhtdocsknews*hadminknews add. php* 


"ERE news. php 


s 

















Nj" M 





* 带 + 号 为 必 填 项 目 
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RIQ 1008 v7T15x 404v T K / 1 fb Unicode (UIF-B) .: 


图 5-90 新 增 新 闻 页 面 设计 


E Recordeet] | 
ER 0 — v[EX-] 


| 


列 : 名 em O wem: 


twpe id 
type name 
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5-91 设置 “记录 集 ” 对 话 框 


动态 列表 / 羔 单 








: |"news type" 在 E “formi” — 
SEED ESI (4) (v) 





玉 自 记录 入 的 进项 [Recorase v 
m: [ma v 


mE: [meam | 


选 职 值 等 于 :| 《?php echo $row Recordsetl[!| 到 








5-92 设置 “动态 列表 /菜单 ”对 话 框 
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G) 本章 中 的 一 个 技术 重点 就 是 要 使 用 PHP 实现 目 动 获取 系统 的 鸭 认 时 间 ， 当 插入 新 
闻 时 能 目 动 生成 当时 的 时 间 。 方 法 是 绑 定 一 个 隐藏 字 段 并 命名 为 news_date， 切 换 到 代码 行 
KERE P: 
«input name-"news date" type="hidden" id2"news date" valuez"«?php 
date default timezone  set( Asia/Shanghai); 
echo date(" Y-m-d"); 


79>"> 


// 设 置 时 间 格 式 和 时 间 区 域 
(4) iF “M” TZE, Æ news add.php 编辑 页 面 ， 再 次 单 击 “ 应 用 程序 ”面板 群 组 
中 “服务 器 行为 ”面板 上 的 国 按 钮 ， 在 弹出 的 菜 蛙 中， 选择 “插入 记录 ”命令 ， 如 图 5-93 
所 示 。 











| aum > | [87] | 


Dw 
文件 全 T wuc a SEO) BAU PAm BAD) 90) MAC) WOW) WPW 


aem adi phat > x DER TID 2ALLLATT ILL edt ghp 

N80» 
Ta mn Y| a- xmam re 
ETE TEA T) Milo £4 uS As 06 O ihis S. c sm Eam J| era 


| Qo» RIA KA Meta Bos/ tn t admit evt d£ pig re". EX c 





||| ps E 
IDOLI EAT JE 
ER ë OA 








MIQ 100€ v o RK/ 1 Uniesde (YTP-8) 


Acowzmsc OXW AUC x 
ORRERA o) 

















5-93 选择 “插入 记录 ”选项 
(5) 在 “插入 记录 ”的 设 定 对 话 框 中 ， 输 入 如 图 5-94 所 示 内 容 。 


RTA. B: a 
连接 : news 
插入 表格 : news 


'news id 是 一 个 Ed: 

"news tue j " FORM. news. title d S Ld 
'news type 从 ! rm news type BEBE Er 

j news cont ent 从 FORM. news cont ent’ 获 职 值 作为 pur x 
'news date! M’ FORM. news date' 获取 值 作 洲 ， 日 期 
'news | author’ 从 'FORM. news _author” 获 职 值 作为 “ 交 本 * 











1B: 无 (Nj 
REN: x 


插入 后 ， 转 到 : |admin. php 











5-04 设置 “插入 记录 ”对 话 杠 








A PHP-* 


(6 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ”面板 上 的 国 
按钮 ， 在 打开 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 。 打开“ 检查 表单 ”对 话 框 ， 设 置 值 都 为 
“必需 的 ”“ 可 接受 ”为 “任何 东西 ” 如 图 5-95 Bran. 





"news ti iode , RJ 
Dl — 


(à: 必需 的 


可 接受 : 名 ”任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 人 | | 到 | | 











图 5-95 设置 “检查 表单 ”对 话 框 
单 击 “确定 ”按钮 回 到 编辑 页 面 ， 束 完成 news_add.php 页 面 的 设计 了 。 


SO eam 











修改 新 闻 页 面 news upd.php 的 主要 功能 是 将 数据 表 中 的 数据 送 到 页 面 的 表单 中 进行 修 





改 ， 修 改 数 据 后 再 将 数据 更 新 到 数据 表 中 ， 页 面 设计 如 图 5-96 所 示 。 



































TC: \hpache\ht docsNnewsVadminknews upd. php EIE 
管理 员 ， 你 好 请 你 修改 新 闻 ^ 
新 闻 标 题 : 
更 新 时 间 : 
新 闻 分 类 : 加 作者 ”= | 
^| 
E 
| 
新 闻 内 容 : 
2l 
Y 
€ E 
<body> AJOA moos v| 66T x 428v 2 K / 1 $9 Unicode (UTF-8) 
图 5-96 修改 狐 闻 页 面 设计 
NN r1 IE P4 
评 细 操作 步 又 如 下 。 


(1) 打开 news upd.php 页 面 ， 并 单 击 “ 绑 定 ”面板 上 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 
择 “ 记 录 集 (查询 )” 选 项 ， 在 打开 的 “记录 和 集 ” 对 话 杠 中， 输入 如 图 5-97 所 示 内 容 。 
(2) 用 同样 方法 再 绑 定 一 个 记录 集 Recordset2， 在 “记录 集 ” 的 设置 如 图 5-98 所 示 。 
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es. 
en: 


x 9 em O wem 





图 5-97 设置 “记录 和 集 Recordset1” 对 话 框 


Zin: Recordset2 | 
表格 : | 和 
a9 全 部 O wem: 





图 5-98 设置 “记录 集 Recordset2” 对 话 框 





(3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 news_upd.php 网 页 中 的 适当 位 置 ， 如 图 5-99 
所 示 。 其 中 加 入 一 个 隐藏 字段 绑 定 news. id. 


(40 在 “更 新 时 间 ” 一 栏 中 必须 取得 系统 的 最 新 时 间 ， 方 法 和 上 和 面 加 隐藏 子 段 取得 时 间 
的 方法 一 样 ， 和 直接 在 初始 值 了 字段 输入 取得 系统 时 间 的 代码 ， 如 图 5-100 所 示 。 


«input name-"news date" type="text" id="news_date" value=" <?php 
date default timezone set('Asia/Shanghai); 

echo date(" Y-m-d"); 

7» 





(50 单 击 “ 新 闻 分 类 ”的 列表 沫 单 ， 在 “新 闻 分 类 ”的 列表 沫 单 属 性 面板 中 ， 单 击 
区 ”和 蕉 .| 按钮 ， 在 打开 的 “动态 列表 /菜单 ”对 话 框 中 ， 设 置 如 图 5-101 所 示 内 容 。 
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T C: NApache*htdocsknews*hadmin|news upd. php* = m i 
NR news. php 
EER. MA? AEA? 





[Recordset1. news_title} 











| |. f£ [ Recordset] 


| IRecordsetl.news content] 


| Ga) EE 


€ TIT | i 
able? <tr> <td> <span. . . > label? [&textarea... J Ly Wy Qj 100$ vi 8667 x 404v 6 K / 1 fh Unicode (UTF-B) — - 





5-99 插入 相应 字段 全 news upd.php 网 页 中 





属性 
立 本 域 字符 宽度 D 类 型 回 单行 @) Osa Osme — GOx 
最 多 字符 数 | | WAAT 多 
OA m) 
[]Ri& 00 


5-100 加 入 代码 取得 最 新 时 间 


uper] Edi as 


Hp Xu) 
ES i^] [v] 
E 





3 Eds SEDEM: 
恒 : 





图 5-101 绑 定 "动态 列表 / 沫 单 ” 


(6) 守成 表单 的 布置 后 ， 要 在 news upd.php 这 个 页 面 加 入 “服务 需 行 为 ”中 “更 新 记 
录 ” 的 设 定 ， 在 news upd.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ” 面 








新 闻 发 布 条 统 开发 





扳 上 的 国 校 钮 ， 在 弹出 的 业 音 中， 选择 “更 新 记录 ”命令 ， 如 图 5-102 所 示 。 
mo 941; Uc) ENG Ro rfc o o ero) ea es |y Qow (oin 





| WR EA ea Bc 














图 5-102 加 入 “更 新 记录 ”命令 


(7) 在 打开 的 “更 新 记录 ”对 话 框 中 ,设置 如 图 5-103 所 示 内 容 。 其 中 news id 设置 为 
主键 。 




















"BRA x 
co ORM. n ws content ARHMBTEM ' TE 
'news date' b FORM. news gor HUATA 日 其 | 
'news author A ' FORM. news author' XE&HNMBÍE 304 








1B: FORM. news id 
jeu. | 整数 y a 主键 








在 更 新 后 ， 转 到 : admin. php E 





5-103 ”设置 “更 新 记录 ”对 话 框 
单 击 “ 确 定 ” 按 钮 ， 即 完成 修改 新 闻 页 面 的 设计 。 








sso 删除 新 闻 页 面 | 








删除 新 闻 页 面 news_del.php 和 修改 新 闻 页 面 差 不 多 ， 如 图 5-104 所 示 。 


示 。 其 方法 是 将 表单 
中 的 数据 从 站 点 的 数据 表 中 删除 。 
详细 操作 步骤 如 下 。 





(1) 打开 news_del.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 外 按钮 ， 接 独 在 弹出 的 这 单 中 ， 选 
择 “ 记 录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 如 图 5-105 所 示 内 容 。 
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T C: NApache*htdocsknews*Sadmininews del.php | 


管理 员 ， 你 好 ， 你 要 删除 此 新 闻 吗 ? 
新 闻 标题 : | 
新 闻 分 类 : 人 者 [| 














es. 
eh. 


























5-105 “记录 集 Recordset1” 对 话 框 


(2) 用 同样 方法 再 绑 定 一 个 记录 集 ， 输 入 设 定 值 ， 如 图 5-106 所 示 。 


Z: 


















































5-106 “记录 集 Recordset2” 对 话 框 








第 5 草 ” 新 闻 发 布 系统 开发 











EE EERAJnews id. All 5-107 Pr. 


S C: ÀpacheNhtdocsinewsNadmininews del. php Dx n 
ERED nens php D 


管理 员 ， 你 好 ， 你 要 删除 此 新 闻 吗 ?3 








新 闻 标题 : [Recordseti.news title] E 
新 闻 分 类 : 作者 | [Recordsetl| 


{Recordset1. news_content} ^ 








新 闻 内 容 : 











v 
MC 93- 462 v | E 
561- v 








D <form. .. > <table> Ctr? <td> CLabel? input...) CIE q 100$ 4/667 x 323v 6 K / 1 $^ Unicode (UTF-8) 














图 5-107 字段 的 插入 


(4) 绑 定 记录 集 后 ， 单 击 “ 痢 闻 分 类” 的 沫 单 ， 在 “新 闻 分 闫 ”的 沫 单 属 性 面板 中 ， 单 
击 区 _ 比 按钮 ， 在 打开 的 “动态 列表 / 亲 单 ”对 话 框 中 设置 如 图 5-108 所 示 内 容 。 








per] pn 


|: |"select" dE RE “formi” vi 
+| | 一 (a) i| 


来 自 记 录 集 的 选项 : 





图 5-108” 绑 定 “ 动 态 列表 /菜单 ” 


(5) 完成 表单 的 布置 后 ， 要 在 news_del.php 这 个 页 面 加 入 “服务 器 行为 ”面板 中 “删除 
记录 ”的 设置 。 单 击 “ 应 用 程序 ”向 板 群 组 中 的 “服务 右 行 为 ”面板 上 的 加 按钮 ， 在 弹出 的 
沫 单 中 ， 选 择 “ 删 除 记 录 ” 命 令 ， 在 打开 的 “删除 记录 ”对 话 框 中 ， 输 入 设 定 值 ， 如 网 5-109 
PI. 

单 击 “ 确 定 ” 按 钮 ， 完 成 删除 新 闻 页 面 的 设计 。 
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首先 检查 是 否 已 定 尺 变 且 : {| 
连接 : v 
表格 : v 
主键 列 : i v 数值 
主键 值 : v news id 
册 除 后 ， 转 到 : 















































3r gr P] 47 2$ UL IRI type. add.php 的 功能 是 将 页 和 面 的 表单 数据 新 增 到 newstype 数据 表 中 ， 
页 面 设计 如 图 5-110 所 示 。 


T C: ÀpacheMhtdocsinews*SadninVtrpe add, php -0X 


请 添加 新 闻 分 类 ， 
新 闻 分 类 名 称 : | | 





body? [C£ormi£orm17] m g 100% — «544 x 1B2« 1 K / 1 $^ Unicode (UTF-8) — - 
5-10 新 增 新 闻 分 类 页 面 设计 


详细 操作 步骤 如 下 。 
C) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 右 行 为 ”面板 中 四 按钮 ， 在 弹出 的 染 单 中 ， 选 
择 “ 插 入 记录 ”命令 ， 在 打开 的 “插入 记录 ”对 话 杠 中， 输入 设 定 值 ， 如 图 5-111 所 示 。 





s EH: | forml 








1 news 








: Inewstvype 























iB: | FORM. type name 








提交 为 : [文本 
插入 后 ， 转 到 : admin. php 














5-111 设置 “插入 记录 ”对 话 框 








pO EELEE 





(20 选择 表单 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 为 ” 面 
板 中 的 外 按钮 ， 在 弹出 的 染 音 中， 选择“ 检 奉 表 单 ” 命 令 。 打 开 “ 检 奏 表单 ”对 话 框 ， 设 置 
“ 什 ” 为 “必需 的 ” “可 接受 ”为 “任何 东西 "” 如 图 5-112 R. 


可 接受 © 任何 东西 O An 
O 电子 邮件 地 址 O mM | | 到 | | 





图 5-112 设置 “检查 表单 ”对 话 框 


(3) 单 击 “确定 ”按钮 ， 完 成 type_add.php 页 面 设 计 。 


EZ 修改 新 闻 分 类 


修改 狐 闻 分 类 页 面 type_upd.php 的 功能 十 将 数据 表 的 数据 送 到 页 面 的 表单 中 进行 修改 ， 
修改 数据 后 再 更 新 全 数据 表 中 。 页 面 设计 如 图 5-113 所 示 。 


im 
iow] 











C: SApache*ht docshnewssadmin*ltrpe upd. php -0X 


请 修改 新 闻 分 类 
分 类 2 黎 :| | 





图 5-113 ”修改 新 闻 分 类 页 面 设计 


详细 操作 步骤 如 下 。 

(1) 打开 type upd.php 页 面 ， 并 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 的 | 册 j 按 
钮 。 接 着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 打开“ 记录 集 ” 对 话 框 ， 在 打开 
的 “记录 集 ” 对 话 杠 中， 输入 设 定 值 ， 如 图 5-114 所 示 内 容 。 

(2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 type upd.php 网 页 中 的 适当 位 置 ， 如 图 5-115 
所 示 。 其 中 绑 定 一 个 隐藏 字段 为 type_id。 

(3) 完成 表单 的 布置 后 ， 要 在 type upd.php 这 个 页 面 加 入 “服务 器 行为 ”中 “更 新 记 
ox" HIKE, TE type upd.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”和 面板 群 组 中 的 “服务 器 行为 ”和 面 
板 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 更 新 记录 ”命令 。 在 打开 的 “更 新 记录 ”对 话 框 中 ， 
























PHP 


输入 设 定 值 ， 如 图 5-116 Wr. 


名 称 ; 
表格 
列 : 名 全 部 O wm. 





5-114 ”设置 “记录 集 ” 对 话 框 


| C: VApachekhtdocsinewsiadminltrpe upd. php* ze 


请 修改 新 闻 分 类 ， 

分 类 名 称 : | fRecordsetl.type name] |Æ | 

: 
SUE 


tr? Cd? input. . . 7] $9 Q, 100€ — »|4T4 x 130v 4 K / 1 fb Unicode QUT] ,: 





5-115 ”字段 插入 全 type upd.php 





formi 








: [news 








newstype 

















ÍB: FORM. type id v 
提交 为 : | 整数 vi zs 
在 更 新 后 ， 转 到 : admin. php | 




















5-116 设置 “更 新 记录 ”对 话 框 








QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 
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Hub ME” T AREATA t e 
删除 新 闻 分 类 


删除 新 闻 分 类 页 面 type del.php 功能 是 将 表单 中 的 数据 从 站 点 的 数据 表 newstype 中 删 
除 。 详 细 操 作 步 又 如 下 。 

(1) 打开 type del.php 页 面 ， 该 页 面 和 更 新 的 页 面 是 一 样 的 。 单 击 “ 应 用 程序 ”面板 群 
组 中 “ 绑 定 ”面板 的 [二 按钮。 接着 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 〈 查 询 )” 命 令 ， 打 开 
“记录 集 ” 对 话 框 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 设 定 值 如 图 5-117 所 示 。 





























gn: Recordset | 

连接 : |news MG 
表格 :newstype O vj 

3:09 2m O wem. 


^" n . 
"pe [ 





K| 5-117 设置 “记录 集 ” 对 话 框 





2) 绑 定 记录 集 后 ， 将 记录 集 的 字段 搬入 至 type del.php 网 页 中 的 适当 位 置 ， 如 
图 5-118 所 示 。 其 中 绑 定 一 个 隐藏 学 段 为 type_id。 








l C: Apache htdocs news hadmin' trpe del.php - 口 闪 


i == 
€ 





to <td> naut... Dp [Ra Q 100€ — «[4T4 x 130v 4 K / 1 ÈP Unicode (UTI 
K|5-118 学 段 插 入 全 type del.php 
(3) 完成 表单 的 布置 后 ， 要 在 type_del.php 这 个 页 面 加 入 “服务 占 行 为 ”中 “删除 记 
K” WE. Æ type_del.php 的 页 面 上 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行为 ” 面 


板 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 删 除 记 录 ” 选 项 。 在 打开 的 “删除 记录 ”对 话 框 中 ， 
输入 设 定 值 ， 如 图 5-119 Wr. 
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首先 检查 是 否 已 定 久 变量 : 




















D|type id {i 数值 
:|URL 参数 

















册 除 后 ， 转 到 : admin. php 








图 5-119 设置 “删除 记录 ”对 话 框 


全 此 一 个 功能 完善 、 实 用 的 网 站 痢 闻 发 布 系统 唤 开 发 完毕 ， 谈 者 可 以 将 本 章 开 发 新 闻 发 
布 系统 的 方法 应 用 到 实际 的 大 型 网 站 建设 中 。 








^v^ 


SIJE 留言 板 管理 系统 建设 





留言 板 管理 系统 可 以 实现 网 站 与 访问 者 之 间 的 沟通 ， 收 集 用 户 意见 和 信息 ， 也 是 网 站 
建设 中 必 不 可 少 的 一 个 重要 系统 。 利 用 留言 板 ， 可 以 为 访问 人 员 提 供 友 言 的 机 会 ， 及 时 、 
准确 地 发 表 目 己 的 观点 。 这 些 观 点 被 保留 在 服务 器 上 的 数据 库 中 ， 而 且 可 以 被 任何 一 个 访 
问 站 点 的 人 所 看 到 。 本 章 将 利用 Dreamweaver 的 “插入 记录 ”和 “查询 ”记录 集 命令 ， 轻 
松 实 现 PHP 留言 系统 的 留言 和 奉 询 留言 的 动态 管理 功能 ， 同 时 开始 初步 掌握 通过 手写 代码 
来 实现 部 分 简单 的 功能 。 





sa MA ATJE) EIU 


要 掌握 以 下 知识 点 : 


留言 板 管 理 系 统 的 结构 搭建 

创建 数据 库 和 数据 库 表 

建立 数据 库 连 接 

掌握 留言 板 营 理 系统 中 创建 各 种 页 面 及 页 面 之 间 传 圳 信息 的 技巧 和 方法 
留言 板 管理 系统 常用 功能 的 设计 与 实现 
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| 系统 整体 设计 规划 























留言 板 管理 系统 在 功能 上 主要 表现 为 如 何 显示 留言 ， 如 何 对 留言 进行 回复 、 修 改 
和 删除 ， 一 个 完整 的 留言 板 管 理 系统 分 为 访问 者 留言 模块 和 管理 者 登录 模块 两 部 分 。 
本 半 要 制作 的 留言 板 管理 系统 的 网 页 及 网 页 结构 ， 如 图 6-1 所 示 。 




















留言 板 管理 系统 


index.php 
访问 者 留言 管理 者 登录 
book.php admin_login.php admin.php 
delbook.php reply.php 


图 6-1 系统 结构 图 
留言 板 管理 系 统 共有 6 个 页 面 ， 各 页 面 的 功能 与 对 应 的 文件 名 称 如 表 6-1 所 示 。 








表 6-1 留言 板 管理 系统 网 页 表 








页 面 名 称 E 能 
index.php 留言 内 容 显示 页 面 ， 显 示 留 言 内 容 和 管理 者 回复 内 容 
book.php 留言 页 面 ， 提 供用 户 发 表 留 言 的 页 面 





admin login.php | 管理 者 登录 入 口 页 面 ， 是 管理 者 登录 留言 板 管理 系统 的 入 口 页 面 





admin.php 后 侣 管理 主页 面 ， 是 管理 者 对 留言 的 内 容 进 行 管理 的 页 面 
reply.php 回复 留言 页 面 ， 管 理 者 对 留言 内 容 进行 回复 的 页 面 
delbook.php 删除 留言 页 面 ， 管 理 者 对 一 些 非法 或 不 文明 留言 进行 删除 的 页 面 





页 面 设计 规划 E 


完成 留言 板 宣 理 系 统 的 整体 规划 后 ， 可 以 在 本 地 站 点 上 建立 站 点 文 件 夹 gbook， 将 要 制 
作 的 留言 板 系 统 文件 夹 及 文件 如 图 6-2 所 示 。 
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文件 和 文件 夹 任务 

Q9 ANNER 

PATAREI 
e 

kg HEHH 


dE php 
xn 


RD 4 0 


| PHP m hp 
«b 5 E AX 


index.php 


«D Tu 


10 个 对 象 24.1 KB 


站 点 规划 文件 


， 我 的 电脑 











网 页 美工 方面 ， 主 要 设计 了 首页 和 次 级 页 面 ， 采 用 的 是 标准 的 堪 右 布局 结构 。 
设计 效果 如 图 6-3 所 示 ， 主 要 是 基于 一 个 BtoC 电子 商务 平台 的 留言 系统 的 开发 。 
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图 6-3 留言 页 面 的 设计 效果 





62 数据 库 设 计 与 连接 


制作 留言 板 管 理 系统 ， 首 先 要 设计 一 个 可 存储 访问 者 留言 内 容 、 管 理 员 对 留言 信息 的 回 
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复 以 及 管理 员 账 号 、 密 码 的 数据 库 文 件 ， 以 方便 管理 和 使 用 。 




















本 数据 库 主 要 包括 “留言 信息 意见 表 ” 和 “管理 信息 表 ” 两 个 数据 表 ,“ 留 言 信息 意 
表 ” 命 名 为 gbook,“ 管 理 信 息 表 ”命名 为 admin. 

制作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL", 进入 MySQL 数据 库 的 管理 面 
板 ， 如 图 6-4 所 示 。 

(2) 单 击 工具 栏 的 Create CHI) 按钮 并 在 打开 的 下 拉 沫 单 中 单 击 选择 “Database CX 
据 库 )” 人 命令， 如 图 6-5 Bp. 





WIE 
p Procedure 
m Function 
yg scheduled Event 
yg UDF 
mue MAI, Report 


Favorite iuery 


Database 





6-4 打开 MySQL 数据 库 管理 界面 6-5 单 击 选 择 “Database” 命 令 


(3) 打开 “Create Database Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“gbook”。 然 后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 6-6 所 示 。 


Create Database Wizard 
Create Database 
Specify the name for a new database 
Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 








Database name gbook 





Register after creating 








Cancel 


6-6 输入 数据 库 的 名 称 gbook 











管理 系统 建设 





(4) 设置 MySQL 数据 库 的 属性 设置 如 表 6-2 所 示 ， 连 接 设 置 如 图 6-7 所 示 。 然 后 再 单 
ik Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


表 6-2 ”数据库 属性 设置 S 





Host name localhost Port 3306 
User name root 
Password admin 


Create Database Fizard 
Create Database 


Set connection properies for a new database 


Host name localhost v | Port 3306 ^ 


User name 




















Password 


a Use server settings 














Collation 











[ ]use tunneling 


Tunneling 
SSH tunneling HTTP tunneling 





[ze ] en ] Coen] 
6-7 ”连接 设置 


(5) 打开 新 建 数据 库 的 SQL 语句 提示 ， 创 建 数据 库 gbook， 直 接 单 击 Next (下 一 步 ) 
按钮 ， 如 图 6-8 Wr. 





Create Database Wizard 
Create Database 
Result SQL statement. Click the Finish button to create a new database. 


Result SAL statement:: 
CREATE DATABASE `gbook`; 








tA 


Click "Finish" to create the database. 











Cancel 


6-8 ”完成 设置 


(6) 单 击 Finish《〈 完 成 ) 按钮 ， 打 开 注册 数据 库 的 设置 画面 ， 选 择 utf8 子 符 集 、 人 简体 中 
文 版 的 GB2312 hk, HAERERE, AU 6-9 所 示 。 









PHP 


Database Registration Info 


Wi Connection | 
Eil Options 
Display Options Host name 
[© Directories 


fV Logs 





User name 








B SSH Tunneling Password 








1i HTTP Tunneling Database name 
Data Options 








Database alias |ghook on localhost 








Client charset (utta 








Font charset 312_CHARSET (Simplified Chinese characters) fs 











ET 
图 6-9 ”选择 简体 中 文 
CI) Hik “OK” GAVO 按钮 ， 就 完成 了 数据 库 gbook 的 狐 增 工作 。 
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数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 
gbook、admin。 建 立 数据 库 后 ， 接 着 再 按 左 边 的 “Connect to Database. 〈 和 连接 数据 库 )” 图 标 


总 将 其 连接 上 。 这 两 张 数 据 表 的 字段 结构 内 容 说 明 如 下 。 





CG) 建立 数据 库 gbook 后 ， 用 上 鼠标 右键 单 击 选择 “Table CRH)” WM, 


中 ， 单 击 选 择 “New Table OIR)” MA, WK 6-10 Pr. 


nagar EE Fs chook on localhost [elrowkl] 
= mii os m D PE 
J Gening Started 

5 Cristi rur rabat 加 Crus Pur Lalo 


Ed Manage existing database lH Create rew database objec 


gf Execute query 


中 Manage permissions 


|) SQL Manager 2007 help system 
E i) MySQL reference 
| :| Internet Resources 


IITEITUITINMEN e) oo rager 2007 home pape n 


LH SEX Manager ZO? on-line documentation e SOL Manager UD FAJ 


6-10 ”开始 建 数 据 表 





在 打开 的 玉音 


(2) 数据 库 右 方面 面 会 出 现 狐 建 数据 表 (Table) 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields CJ E20", “DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 


gbook， 如 图 6-11 所 示 。 











B & a 


L ] LJ 


zs New Table — [gbook on localhost] 





| 8 gbook on localhost [gbook v| 


com DWNG) 


4f Compile 
f Q9) Show SQL help 
[P] Restore default size 





Table |Fields | DDL | 


SME RE 





Table Properties 





Table name 











Storage Options 
Storage engine 


Row format 


^|  Min.rows 























^|. Max. rows 








; Auto increment value 


^| Average row length 








<>< >< >| < < > 





^| Size for index key blocks 
[C] Delay key write 
[C] Temporary 


^|. [C] Check sum 
[C] Pack keys 





Character Sets | File Options | Merge Table Options | Federated Table Options | 








Character set Default v 














Collation Default v 











6-11 输入 数据 表 名 gbook 


G) 然后 再 切换 到 “Fields 内容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设 症 数据 域 位 的 相关 
数据 ， 如 图 6-12 所 示 。 对 访问 者 的 留言 内 容 做 一 个 全 面 的 分 析 ， 设 计 gbook 的 字段 结构 如 
X 6-3 ZR. 


mR Table Igbo ik ] Ighn ok or Orn un: 
- ^ FedTye Sue Pres. Nu Ma Delad 
ju Le id | INILGER 11 


Lr 





i] Refresh 
g Compie 
| Qr Grants on todie 
ces Prin 

taj Show SUL help 
(d; Table Editor options 


VARCHAR 50 
VARCHAR — 20 


(gi Restore detinut stre 





图 6-12 设置 数据 库 


表 6-3 留言 信息 表 gbook 


字段 大 小 Dd EE 


WRARNEE | mpy | TEXT | | 
重点 提示 : 在 此 例 中 ， 管 理 者 可 以 通过 passid 字段 对 留言 审核 是 否 通过 进行 标注 。 
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(4) 创建 admin 数据 表 ， 用 于 后 台 管 理 者 登录 验证 用 ， 输 入 数据 域名 以 及 设置 数据 域 位 
的 相关 数据 ， 如 表 6-4 及 图 6-13 所 示 。 


表 6-4 EH Sua admin 


是 


密码 password VARCHAR 


£ Table — [admin] — [gbook on localhost] 


Object S| | Properties | Fields Indices | Triggers | Data | Dependencies | DDL 

r 一 一 Field Name Field Type Size Preci... Mot N... Default Comment 
gbook on localhost [gbi w s 

| ag INTEGER |11 |o | Null 


时 admin S E username VARCHAR 50 0 Null 


[a Refresh 
f Compile 
ə Grants on table 

















Q9) Show SQL help 
(d Table Editor options 
加 Restore default size 


ES! Add new field 
E Edit selected field 
s4 Drop selected field(s) 














图 6-13 创建 的 admin 数据 表 





数据 库 创建 完毕 ， 对 于 本 系统 而 富有 的 新 拉 术 是 如 何 取得 访问 者 的 他 地 址 。 


\ 定义 gbook 丫 点 ) 


在 Dreamweaver CS 5.5 中 创建 一 个 “留言 板 管 理 系 统 ” 网 站 站 点 gbook， 由 于 这 是 PHP 
数据 库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 。 主 要 的 参数 设置 如 表 6-5 所 示 。 





表 6-5 站 点 设置 的 基本 参数 


站 点 名 称 gbook 
本 机 根 目 录 C:\Apache\htdocs\gbook 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhost/gbook/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All Users\Application DataMySQLWySQL Server 5.5\data\gbook 
管理 账号 / 密码 root / admin 
数据 库 名 称 gbook 


创建 gbook 站 点 的 具体 操作 步骤 如 下 。 
(1) 首先 在 CAMApacheMtdocs 路 径 下 建立 gbook 文件 来， 如 图 6-14 所 示 ， 本 章 所 有 建立 


的 网 页 文件 都 将 放 在 该 文件 夹 下 。 





ME C: V. EH (C39 eoi DE: 
wH AmE 查看 WW) Bwa 工具 (T) RH) 
QAE- 29.05 Ps p xtX [Du 


| 地 址 m0) ES C: ApacheWhtdoes 转 到 
^| 名 称 和 大 小 ”类 型 修改 日 期 











Xr IXUS A c .mmServerScripts Arp 2011-7-6 16:06 
个 文件 来 2011-7-11 10:29 
mij nid 六 文件 天 文件 来 2011-T-T 22:04 
(y 移动 这 个 文件 来 MALES 2011-7-9 8:00 
[D 复制 这 个 文件 来 立 件 来 2011-6-15 9:41 
Q 将 这 个 文件 夹 发 布 到 也 phpwyAanin AH apio us 
o Web Ø shop 文件 来 2011-6-30 15:30 
共享 此 文件 来 Bi test AX 2011-T-6 15:55 
A 以 电子 邮件 形式 发 送 &] index. html 1 KB HINL 文档 2004-11-20 15:16 


该 文件 来 内 的 文件 ind 
K MERTXEK = test. php 1 Kb PHP 文件 2011-7-6 8:35 





选 定 1 44$ 





6-14 ”建立 站 点 文件 夹 gbook 





(2) 运行 Dreamweaver CS 5.5, Wx s rnm 
“站 点 ”一 “管理 站 点 ”人 命令， 打开“ 管理 站 点 ”对 
话 框 ， 如 图 6-15 所 示 。 

G) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 
有 已 经 定 义 的 站 点 。 单 击 右边 的 “新 建 ” 按 钮 ， 打 开 
“站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”: gbook。 

“本 地 站 点 文件 来” C:\Apache\htdocs\gbook. 


如 图 6-16 所 示 。 


站 点 设置 对 锡 gbook 




















6-15 “管理 站 点 ”对 话 框 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
夹 ， 以 及 可 在 其 中 将 相同 文件 发 布 到 web 上 的 服务 器 上 的 远程 文件 来 。 











您 可 以 在 此 处 当 Dreamweaver 站 点 选择 本 地 文件 夹 和 名 称 。 
站 点 名 称 : 
AHi diri: | C'\Apachehhtdocs\gbook% 5 





6-16 ”建立 gbook 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 此 |， 打 开 “ 基 本 ” 
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选项 卡 ， 进 行 如 图 6-17 所 示 的 参数 设置 。 
“服务 絮 名 称 ” gbook. 
“连接 方法 ” 本 地 /网 络 。 
“服务 絮 文 件 来” C:\Apache\htdocs\。 
“Web URL”: http:// localhost/gbook/. 


靖 点 设置 对 儿 gbook 


服务 器 名 称 
连接 方法 
服务 器 文件 
web Rs 











6-17 设置 “基本 ”选项 卡 


(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同步 
言 息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 6-18 所 示 。 


站 点 设置 对 锡 gbook 





远程 服务 器 





M 维护 同步 信息 
口 ] 保存 时 自动 将 玄 件 上 传 到 服务 器 
O 自用 文件 职 出 功能 

[V 打开 文件 之 前 取出 


取出 名 称 : O 





电子 邮件 地 址 : 





6-18 设置 “高 级 ”选项 卡 


(6) 单 击 “ 人 保存” 按钮， 返回 “服务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 按钮 ， 
如 图 6-19 所 示 。 





板 官 理 系 统 建设 


一 


站 点 设置 对 和 锡 gbook 


您 将 在 此 位 置 选择 学 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 


T — Internet 服务 提供 商 (SP) 或 web 管理 员 。 


版 本 控制 


p SARE 注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步 又。 如 果 要 连接 到 Web 并 发 
AU. DEVE SEN. 
dS UA 


6-19 UE "Horus 23 








单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 
刚 所 设置 的 站 点 gbook。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 杠 ， 这 样 束 完成 了 
Dreamweaver CS 5.5 测试 留言 板 管理 系统 网 页 的 网 站 环境 设置 。 











完成 了 站 点 的 定义 后 ， 接 下 来 就 是 留言 板 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数 


据 库 的 连接 设置 如 下 。 
(1) 将 区 盘 中 设计 的 本 章 文件 复制 到 站 点 文件 夹 中 ， 打 开 index.php, Anl 6-20 所 示 。 
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图 6-20 ”打开 网 站 首页 











f PHP+ 


(2) 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 命 令 ， 打 开 “ 数 据 库 ”面板 。 在 “数据 
库 ” 面 板 中 ， 单 击 选 择 “+” 图 标 ， 并 在 打开 的 菜单 中 选择 “MYySQL 连接 ”命令 ， 如 图 6-21 
所 示 。 
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L JATE 站 点 。 
2. WEE TENUES, 
«^ 3. 设置 站 点 的 Mi 
4.” 单 击 上 面 的 + IER REERE. 


图 6-21 选择 MySQL 连接 


(3) Æ “MySQL 连接 ”对 话 框 中 ， 输 入 “连接 名 称 ” 为 gbook, “MySQL 服务 器 ”名 
Jj localhost, “用户 名 ”为 root, 1A admin， 如 图 6-22a 所 示 。 选 择 所 要 建 并 连接 的 数据 
库 名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 ， 浏 览 MySQL 服务 器 上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 
数据 库 gbook， 具 体 的 设置 内 容 如 图 6-22b 所 示 。 


ESEN: 
iysqr REE 
ss. 

d 





performance schemaold 





b) 
图 6-22 WE MySQL 连接 参数 


(4) fau; "uA Ju, MAS MySQL 数据库 的 连接 是 否 正 确 ， 如 果 正 确 则 会 出 现 一 
个 消息 框 ， 如 图 6-23 所 示 ， 这 表示 数据 库 连 接 设 置 成 功 。 








5 理 系 统 建 设 


下 FY3QL 连接 


Dreamweaver 


和 连接 名 称 : 


"SQL 服务 器 : | | i ) 成功 创建 连接 脚本 。 
HP] o 
xr. 确定 


AEE: |E 





6-23 ”设置 成 功 


单 击 “ 人 确定 ”按钮 ， 返 回 编 辑 页 面 ， 在 “数据 库 ” 和 面板 中 则 显示 绑 定 过 来 的 数据 库 ， 如 
图 6-24 所 示 。 


Hugm|epe, 服务 器 行为 | = 


+t 一 GUESS: PH C 






E T Ebook 
SE MEg 
E- ERI admin 


E1- 视图 
E-e TAE 







6224 ” 绑 定 的 数据 库 


留言 板 管理 系统 页 面 
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留言 板 管理 系统 分 前 台 和 后 从 两 部 分 ， 这 里 首先 制作 前 合 部 分 的 动态 网 页 。 


6.3.1 


在 首页 index.php 中 ， 单 击 “ 留 言 ” 链 接 时 ， 打 开 留 言 页 面 book.php， 访 问 者 可 以 在 上 
面目 由 发 表意 见 ， 但 管理 员 可 以 对 非法 或 不 文明 留言 进行 删除 、 修 改 等 。 

其 详细 制作 的 步 又 如 下 。 

C1) HARPA KIM index.php, WEE “现在 时 间 是 :” 后 面 加 一 个 PHP 代码 : 


<?php 
date_default_timezone_set('Asia/Shanghai'); 
echo date("Y-m-d h:1:s"); 

7> 


得 到 系统 的 当前 时 间 ， 在 文字 “留言 ”上 做 一 个 超 链接 ， 链 接 到 book.php, XR Ul 
图 6-25 所 示 。 
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ec: SÀpache'htdocsgbook^indez. phi 


| PPan 


ALS i Sedes M NES 


EST EXIT e | IORSRIFAHESEGRDE + 请 单 击 背 言 结 我 们 留言 ， D Xinss-MiaMemeN. 
is in —3 


E guns DEAF: 


: ESTEE: 





lady» tabe dy 45 able SaD td? tablet Ctr? ted [Ry 100$ Tr x Me 125 E / 3 È Unicode (UTF-8) 


6-25 HONORI 


(2) 执行 菜单 “窗口 ”一 “ 绑 定 ”命令 ， 打 开 “ 绑 定 ” 面 板 ， 单 击 “ 比 定 ” 面 板 上 的 按 
钮 外， 在 弹出 的 菜单 中 选择 “记录 集 (查询 )” 命 令 ， 在 该 对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 “记录 集 ” 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 

4) 在 “ 列 ” 单 选 按钮 组 中 选择 “全 部 ” 单 选 按钮 。 

完成 后 的 设置 如 图 6-26 所 示 。 





» 9 全 部 O sem. 
In 
subject 


content 
reply 
date 





mt E 0 00 ve 
[EL 参数 [DL | 
排序 无 上 
























































6-26 设置 “记录 集 ” 对 话 框 


(3) 单 击 “ 局 级 ”按钮 ， 进 行 蜗 级 模式 绑 定 ， 在 SQL 文本 框 中 输入 如 下 代码 : 
SELECT * 


FROM gbook /从 数据 库 中 选择 gbook 表 
WHERE passid-0 /选择 的 条 件 为 passid X 0 
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当 此 SQL 语句 从 数据 表 gbook 中 查询 出 所 有 的 passid 字段 值 为 0 的 记录 时 ， 表 示 此 留 
言 已 经 通过 管理 员 的 审核 ， 如 图 6-27 所 示 。 





: gbook 














: SELECT * 
FROM ebook 
WHERE passid=0 














d. Hund 





6-27 输入 SQL 语句 


(4) 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 绑 定 ， 然 后 将 此 字段 插入 全 index.php 网 页 的 适 
当 位 置 ， 如 图 6-28 所 示 。 


= C: Nl pacha'ht doesigbook' inder. phpt =- OX 


| dock phe 


d sem cHEES :| 
Ls Dm gk : 
col BEITHAREE DE, ARENE. A 我 们 会 第 一 时 间 给 你 答复 。 : 
E E o eese 
.  SRBIRsIPRONEX RENS: 
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3 ers E LETETT ASA RR 
: ERRE Fa sia EIPS: 





WS AA Gr 4b Calle "— Cform£orml1? [k]£) om  . TH x 416v 1298 E / 3 £9 Unicode QITF-8) . 


6-28 插入 相应 字段 全 index.php 网 页 


(5) 在 “管理 回复 ”单元 格 中 ， 根 据 数 据 表 中 的 回复 字段 reply 是 人 否 为 衬 ， 来 判断 管理 员 是 
否 访 问 过 。 如 果 该 字段 为 宝 ， 则 显示 “对 不 起 ， 暂 无 回复 !” 字 样 信息 ， 如 采访 字段 不 为 衬 ， 耽 
表明 管理 员 对 此 留言 进行 了 回复 ， 同 时 还 会 显示 回复 的 时 间 和 内 容 。 

(6) 在 设计 视图 上 ， 选 中 “管理 回复 ”单元 格 ， 找 到 “对 不 起 ， 暂 无 回复 !” 字 样 ， 并 
加 入 代码 ， 如 图 6-29 所 示 。 
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€ C: \Apache\ht docsVgtook Ni ndez. php .Dx 


€ nex Y 
O xin. o 


<td bgcolor=" 8F3F3F3" WSs 
«td height="30" bgcolor "Fors € 
€td»«table vidths"1005" borders"O0" cellspacings"0" cellpsddings"0"» 





colspane"3" bg ore"AF3F3F2"»&nbsp:* 





Cable) C? CD Corn. |. 5 Gable? Cu? 4D Cable? Gu] 129 K / 3 F^ Vaicede MPO) — 


图 6-29 ”加 入 代码 


<?php 
if ( $row_Rs['reply']= empty( $row. Rs['reply'])) { 

echo "XJA, HEER! "yR repy FRA TUER 
else( ?> /l'a A A RI S ZR EA PITE 


«br /> 





管理 员 在 <?php echo $row. Rs['redate']; ?> 回复 内 容 : «br /> 


<?php echo $row. Rs['reply']; }?> 


重点 提示 : 通过 df..else 条 件 判 断 语 名 实现 判断 的 功能 。 


CI) 由 于 index.php 负面 显示 的 是 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 只 会 显示 数据 
库 的 第 一 笔 数据 ， 因 此 需要 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 选 择 index.php 页 
面 中 记录 的 那 一 个 表格 ， 如 图 6-30 所 示 。 
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图 6-30 选择 要 重复 显示 的 内 容 
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(80 单 击 “应 用 程序 ”面板 群 组 中 “服务 喜 行 为 ”面板 中 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“重复 区 域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 显 示 的 数据 选项 ， 如 疼 6-31 rn. 














图 6-31 设置 “重复 区 域 ” 对 话 杠 


(9) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设 定 。 

(10) 鼠标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “数据 ”类 别 中 ， 单 
击 | 到 工具 按钮 ， 在 弹出 的 对 话 框 中 选取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 如 图 6-32a 所 
示 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 此 时 页 面 孢 会 出 现 该 记录 集 的 导航 条 ， 效 果 如 
| 6-32b 所 示 。 
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图 6-32 加 入 “记录 集 导 航 条 ” 
(11) 将 鼠标 移 至 页 面 表格 的 右上 角 ， 并 在 “插入 ” 列 的 “数据 ”类 别 中 ， 单 击 | 加 工具 
按钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 显示 状态 的 记录 集 ， 如 图 6-33a PR, PA ME” T 
钮 ， 回 到 编辑 页 面 ， 此 时 页 面 束 会 出 现 该 记录 和 集 的 导航 状态 ， 如 图 6-33b Pr. 
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图 6-33 加 入 “记录 集 导航 状态 ” 


-de I K/3 5 Wicd MTA — 





人 至此， 留言 板 的 首页 index.php 设计 完成 。 打 开 IE 浏览 器 ， 在 地 址 栏 中 输入 


http://127.0.0.1/ index.php， 对 首页 进行 测试 ， 由 于 现在 数据 库 中 没有 数据 ， 所 以 测试 效果 如 
图 6-34 所 示 。 
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6-34 留言 板 管理 系统 主页 测试 效 末 
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6.3.2 | 


本 节 将 要 制作 访问 者 在 线 留言 功能 ， 其 主要 技术 是 通过 “服务 器 行为 ”面板 中 的 “插入 QU 





记录 ”功能 ， 实 现 将 访问 者 填写 的 内 容 插入 到 数据 表 gbook 中 。 

详细 的 制作 步骤 如 下 。 

(1) 执行 末 单 “文件 ”一 “新 建 ” 命 令 ， 打 开 “ 新 建文 档 ” 对 话 框 ,创建 新 页 面 。 执 行 
亲 单 “文件 ”一 “为 存 为 ”命令 ， 将 新 建文 件 在 根 目录 下 你 存 为 book.php。 

(20 供 访问 者 留言 的 静态 页 面 book.php， 与 主页 面 index.php 4355. 2C Ul 6-35 
所 示 。 











四 C:\Apache\htdocs\Ebook\book. php Sal 


F BALARA 








eS 
<body> <table> <tr> <td> 
6-35 ”设计 的 book.php 页 面 效 果 


(3) 在 留言 板 表单 内 部 ， 分 别 执行 3 次 “搬入 记录 ”一 “表单 ”一 “隐藏 区域 ”命令 。 
插入 3 个 隐藏 区域， 选中 其 中 一 个 隐藏 区域， 将 其 命名 为 PP， 并 在 属性 面板 中 对 其 赋值 ， 如 
图 6-36 PZR o 


«input name-"IP" type="hidden" idz"IP" value="<?php echo $_ SERVER[REMOTE ADDR'];?»"/» 
/ 目 动 取得 用 户 的 卫 地 址 








A] Feli. 1e 


IB (V) php echo $ SERVER[ REMOTE ADDE 47 
























































6-36 ix IP 


(40 再 选择 另外 一 个 隐藏 区 域 命 名 为 date， 并 在 “ 值 ” 文 本 框 中 输入 获取 系统 时 间 的 代 


tun 6-37 所 示 。 


«input name="date" type="hidden" id="date" value=" <?php 
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date default timezone set('Asia/Shanghai); 
echo date(" Y -m-d h:i:s"); 
?>">/ 获 取 系 统 即 时 时 间 


EIE 


IN] ci DE eh 
iB(V) |Cphpdate default timezone setl 7 











6-37 设置 date 


(50 同样 设置 第 3 个 隐藏 区 域 的 字段 名 称 为 passid,“ 值 ”为 0， 表 示 任 何 留言 者 在 留言 时 
生成 的 passid 值 为 0， 管理 者 可 以 根据 这 个 值 进行 判 新 ， 方 便 后 面 的 管理 。 如 图 6-38 所 示 。 





RE 
NI ES [x det 
iB) o 7 





6-38 设置 passid 值 为 0 


(60 单 击 “应 用 程序 ”面板 数目 中 的 “服务 堪 行 为 ”面板 中 的 邮 j 按 钮 ， 在 弹出 的 沫 单 
中 选择 “插入 记录 ” 在 打开 的 “插入 记录 ”对 话 框 中 设置 如 下 参数 。 

D 从 “连接 ”下 拉 列 表 框 中 选择 连接 对 象 为 gbook。 

2) 从 “搬入 表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 

3) 在 “插入 后 ， 转 到 ”文本 框 中 输入 index.php. 

4) 在 “ 列 ” 列 选项 中 会 自动 配置 相应 的 字段 插入 ， 其 中 没有 配置 的 值 是 供 管理 者 进行 
插入 使 用 的 。 

完成 后 的 设置 如 图 6-39 所 示 。 
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P^ FORM. date’ 获取 值 作 浇 “日 期 ' 
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插入 后 ， 转 到 : index. php 











6-39 ”设置 “搬入 记录 ”对 话 框 
N ) A WME” A, PAAR irit, MAh book.php“ 插 入 记录 ”的 
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(8) 有 坚 访 问 者 进入 留言 页 面 book.php 后 ， 不 填 任 何 数据 区 直接 把 表单 送出 ， 这 样 数 
据 库 中 就 会 自动 生成 一 笔 空 白 数 据 。 为 了 阻止 这 种 现象 的 发 生 ， 须 加 入 “检查 表单 ”的 行 
为 。 有 具体 操作 是 在 book.php 的 标签 检测 区 中 ， 单 击 <forml> 这 个 标签 ， 然 后 再 单 击 “ 行 为 ” 
面板 的 按钮 节 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 奉 表 单 ” 命 令 。 

49)“ 检 和 奋 表 单 ” 行 为 会 根据 表单 的 内 容 来 设 定 检 得 方式 ， 留 言 者 一 定 要 盾 入 标题 和 拓 
容 ， 因 此 将 subject, content 这 两 个 字段 的 值 义 选 “必需 的 ” 复 选 按钮 ， 这 样 就 可 完成 “检查 
表单 ”的 行为 设 定 了 。 有 具体 设置 如 图 6-40 HR. 




















input "username" 
input password" 
: input subject" 





可 接受 : ”任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 | | 到 | | 





6-40 WE AAKE” ODE 
单 击 “ 确 定 ” 控 钮 ， 完 成 留言 负面 的 设计 。 





于 是 ”后 台 管 理 功能 的 设计 








言 板 后 台 管 理 系 统 可 以 使 系统 管理 员 通 过 admin_login.php 进行 登录 管理 ， 管 理 员 登 
录 页 面 的 设计 效果 如 图 6-41 所 示 。 








四 C: AApachekht docskgbook*Nadmin login. php -Dx 











<body> <form#forml > R] Q 100% 4/571 x 169v 1 K / 1 f? Unicode (UTF-8). 





6-41 管理 员 登 录 页 而 








管理 页 面 是 不 允许 一 般 网 站 访问 者 进入 的 ， 必 须 受 到 权限 约束 。 
详细 操作 步 又 如 下 。 





f PHP + QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


(1) 打开 制作 的 静态 页 面 admin_login.php。 单 击 “ 应 用 程序 ”和 面板 群 组 中 的 “服务 器 行 
为 ” 面板 上 的 按钮 [出 ， 在 弹出 的 菜单 中 ， 选 择 “ 用 户 身 份 验证 /登录 用 户 ” 命 令 ， 弹 出 “ 登 
录用 户 ”对话 框 ， 在 这 里 做 如 下 设置 如 果 不 成 功 ， 将 返回 主页 面 index.php; 如 果 成 功 ， 将 
登录 后 台 管 理 主页 面 admin.php， 如 图 6-42 所 示 。 




















从 表单 获取 输入 : | forml 
用 户 名 字段 : username 
密码 字段 : password 

















使 用 连接 验证 :| ebook 
表格 : | admin 

用 户 名 列 : username 

密码 列 : password 


























如 果 登 录 成 功 ， 转 到 : admin. php pls... 


[] 转 到 前 一 个 URL( 如 果 它 存在 ) 
如 果 登 录 失 败 ， 转 到 : index.php pls... 

















基于 以 下 项 限制 访问 : © ”用户 名 和 窗 码 
〇 ”用 户 名 、 密 码 和 访问 级 别 
获取 级 别 自 : ;1 








图 6-42 设置 “登录 用 户 ” 对 话 框 


(2) 执行 菜单 “窗口 ”一 “行为 ”命令 ， 打开“ 行为” 面板， 单 击 “行为 ”面板 中 的 
[出 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 
username 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”， “可 接受 ”为 “任何 东西 ”如 图 6-43 
所 示 。 

(3) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 管 理 员 登 录入 口 页 面 admin login.php 的 设计 
与 制作 都 已 经 完成 。 





[input "username" (R) 
input "password" (R) 
het : 








mx. © gaza 〇 数字 
O 电子 邮件 地 址 O 数字 从 | | 到 | | 





图 6-43 WB "Rex out 





后 台 管 理 主页 面 


后 台 管 理 主 页 面 admin.php 是 管理 员 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 这 个 页 面 


























板 管理 系统 建设 


提供 删除 和 编辑 留言 的 功能 ， 效 果 如 图 6-44 所 示 。 


四 C:\Apache\htdocs\Ebook\admin. php -Dnx 


PHP. 







x] xs rH 
H r1 已 2 





Copyright(32011-2012 hbculture.com Inc.All rights reserved. 环 博 文化 版 权 所 有 g 


< 
<body> <table> <tr> «a» KoA 


< 





lili 


FN 
A]? Qj 10058 4| T82 x 348» 53 K / 2 fb Unicode (UTF-8) 











图 6-44 “管理 主页 面 ” 的 设计 效果 

详细 操作 步骤 如 下 。 

(1) 打开 admin.php 页 面 ， 此 页 面 设计 比较 简单 ， 在 这 里 不 做 详细 说 明 。 单 击 “ 绑 定 ” 
面板 上 的 | 曲 按 钮 ， 在 弹出 的 对 话 框 中 ， 选 择 “ 记 录 集 (查询 )” 命 令 ， 在 打开 的 “记录 和 集 ” 
对 话 框 中 进行 如 下 设置 。 

D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 gbook。 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 象 为 gbook。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5) 设置 “排序 ”方法 为 以 ID 降序 。 

再 单 击 “确定 ”按钮 后 就 完成 设 定 ， 如 图 6-45 所 示 。 























am: Bs | 
i 
列 : 9 全 部 O wem. 





sm 





图 6-45 设置 “记录 和 集 ” 对 话 框 





(2) 绑 定 记录 集 后 ， 将 记录 集 字 段 插入 至 admin.php 网 页 的 适当 位 置 ， 如 图 6-46 所 示 。 












PHP+ QL-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


T C: XÀpacheXht docskgbook'a dmin. php -0x 


CES book. php 


首页 | 新 闻 动 态 | 信息 服务 言 筷 知识 BEP TS Ip Wm 
| 你 的 位 置 : ESENE | 

















:ReID) Rs subject} (Rs content) i "| WE BEC. 


Copyright(32011-2012 hbculture.com Inc. All rights reserved. 环 博文 化 版 权 所 有 











一 一 <table> <tr> <td> <table> <tr> <td> <table> <tr>Ktd) "AES Q 100€ v182 x 324« 56 K / 2 15 Unicode (VIF-8) - 
图 6-46 插入 字段 全 admin.php 网 页 
(3) admin.php 页 面 的 功能 是 显示 数据 库 中 的 部 分 记录 ， 而 目前 的 设 定 则 上 只 会 显示 数据 


库 的 第 一 笔 数 据 ， 需 要 加 入 “服务 器 行为 ”中 的 “重复 区域” 命令 ， 选 择 admin.php 页 面 中 
与 记录 有 天 的 那 一 行 表格 ， 如 图 6-47 所 示 。 











9596 (712) v 













Sb 


it 
图 6-47 选择 要 重复 的 内 容 


(4) 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行 
为 ”面板 上 [由 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 重 复 区 
域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 置 一 页 
显示 的 记录 数 ， 例 如 10 条 记录 ， 如 图 6-48 所 示 。 

(5) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 会 发 现 先 
前 所 选取 要 重复 的 区 域 左上 角 出 现 了 一 个 “重复 ”的 灰 
色 标 签 ， 这 表示 已 经 完成 设置 。 

(6) 首先 选取 记录 集 有 记录 时 ， 要 显示 的 记录 表格 如 网 6-49 所 示 。 


Ei C: \Apache\htdocs\ebook\admin. php -0x 


EAE zbook php 


(Rs 1D) Rs.content) 









































图 6-48 设置 “重复 区 域 ”对 话 杠 

















E 你 的 位 置 : 管理 主页 面 


2896 (198) v 


Copyright(32011-2012 hbculture.com Inc. All rights reserved. 环 博文 化 版 权 所 有 





< TT Fm 
Le? <tr> € P [<table ! <tr> <td> [k] Q 1008 v7T82 x 324v 5T K / 2 $5 Unicode (UTF-8) 


图 6-49 选择 有 记录 时 显示 页 面 
CI) 单 击 “ 服 务 需 行 为 ”面板 中 的 外 按钮 ， 在 弹出 的 集 音 中， 选择 “显示 区 域 / 如 果 记 
录 集 不 为 空 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 选 择 
“记录 集 ” 下 拉 列 表 框 中 的 “Rs” 选 项 ， 如 图 6-50a 所 示 ， 再 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 


















































页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左上 角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰 
色 卷 标 ， 这 表示 已 经 完成 设 定 ， 如 图 6-50b Br. 





o fE-T 2S zr M aom 





T C:\Apache\htdocs\Ebook\admin. php* 


HIRED abook. php 





T82 x 324v S8 K /2 秒 Unicode (UTF-B) — : 





6-50 ”完成 的 设置 
(8) 输入 记录 集 没 有 记录 时 要 显示 “目前 没有 任何 留言 >， 如 图 6-51 所 示 。 











T C: XApachekht docsNgbook*a dmnin. php* 


Pha book php 


PHP wi 


RsID) :{Rs.subject} E 
m 前 没有 任何 留言 


| 国 "i 
<body> <table> Ctr? <td> <table> <tr> <td> RIVA 782 x 324v 58 K / 2 Æ Unicode (UTF-8B) — -: 


图 6-51 选择 没有 记录 时 显示 页 面 

(9) 单 击 “服务 占 行 为 ”面板 中 的 昌 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 显 示 区 域 / 如 果 记 
录 集 为 空 则 显示 区 域 ”命令 ， 在 打开 的 “如 果 记 录 
集 为 空 则 显示 区 域 ” 对 话 杠 中， 选择 “记录 集 ” 下 DIERAN 
MIRER HI “Rs” WW, HA "sk Ael 
到 编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 
角 ， 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 ”的 灰色 
郑 标 ， 这 表示 已 经 完成 设 定 ， 如 网 6-52 Bp. 









































图 6-52 设置 “如 果 记 录 集 为 空 则 显示 区 域 ” 












PHP+ QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





(100 将 光标 移 至 要 加 入 “记录 集 导 航 条 ”的 位 置 ， 在 “插入 ” 栏 的 “应 用 程序 ”类 别 
中 ， 单 击 国 工具 按钮 ， 在 弹出 的 对 话 框 中 ， 选 取 要 导航 的 记录 集 以 及 导航 的 显示 方式 ， 如 图 
6-53a 所 示 ， 然 后 单 击 “ 确 定 ” 控 钮 回 到 编辑 页 面 ， 会 及 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 
图 6-53b 所 示 。 














显示 方式 : © yE 


O mg 








T C:\Apache\ht docs\Ebook\admin. php* -Bx 


首页 | 新 闻 动 态 | 信息 服务 | 信息 知识 | 信息 产业 | EG | AAR 


EE 
目前 没有 任何 留言 











图 6-53 ”加 入 “记录 集 导 航 条 ?” 
(11) 单 击 页 面 中 的 “回复 ”文学 ， 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 
“浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 ， 选 择 用 来 显示 详细 记录 信息 的 页 面 
reply.php， 设 置 如 图 6-54 PZR. 





选择 文件 名 自 : GERI 站 点 根 目录 
〇 数据 源 


站 点 和 服务 器 ... 





查找 范围 加 :| O ebook «odorum 


(C3. mmServerScripts 


(3). notes 


[Connections 


O dated 
(images 


Mcd admin. php 


WA 0: reply. php 


次 件 类 型 (T): | 所 有 文件 (o) Y 



































VRL: reply. php 


相对 于 : arp * | admin. php 


在 站 点 定义 中 更 改 默 让 的 链接 相对 于 











6-54 ”选择 链接 文件 














(12) 单 击 “ 参 数 ” 按 钮 ， 设 置 超级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 DD， 值 设置 如 图 6-55a. b 所 示 。 














Jl 


<?php echo $row Rs[ ID... 





格式 : 无 


HH: <?php echo $row Rs['ID']; ?> 











a) 
图 6-55 “参数 ”和 “动态 数据 ”对 话 框 
(13) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 选 取 编 辑 页 面 中 的 “删除 ”二 字 ， 在 “属性 ” 
面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “浏览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选择 
用 来 显示 详细 记录 信息 的 页 面 delbook.php， 并 设置 传递 ID 参数 ， 如 图 6-56a、b 所 示 。 








选择 文件 名 自 : 人 文件 系统 EIE J 


SRE T): | 加 ebook — |. Wdodrtm 














XA:  |delbook. php | 


TSE C): | 所 有 文件 (e v| [ 取消 











| delbook. php?ID-4?php echo $row Rs['ID']; | 








图 6-56 设置 “删除 ”的 链接 
(145 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 中 的 “服务 器 行 
为 ” 面板 上 的 [出 | 按钮 ， 在 弹出 的 沫 单 中 选择 “用 户 身 份 验证 /限制 对 页 的 访问 ”命令 ， 在 打 
开 的 “限制 对 页 的 访问 ”对 话 框 中 ， 选 择 “ 如 果 访 问 被 拒绝 ， 则 转 到 admin login.php 页 
面 ， 如 图 6-57 Pp. 








基于 以 下 内 容 进 行 限制 : © ”用 户 名 和 密码 
〇 ”用 户 和 名、 密码 和 访问 级 别 


选 职 级 列 : 


如 果 访问 被 拒绝 ， 则 苇 到 : [aanin_ login php 














图 6-57 设置 “限制 对 页 的 访问 ”对 话 框 











"s PHP+ QL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 


单 击 “确定 ”按钮 ， 就 完成 了 后 人 台 管 理 页 面 admin.php 的 制作 。 


EZE 


回复 留言 的 功能 主要 通过 reply.php 页 面 对 用 户 留 言 进 行 回 复 ， 实 现 的 方法 是 将 数据 库 
的 相应 字段 绑 定 到 页 面 中 ， 管 理 员 在 “回复 内 容 ” 中 盾 写 内 容 ， 单 击 “ 回 复 ” 按 钮 ， 可 以 将 
回复 内 容 更 新 到 gbook 数据 表 中 ， 页 面 效 果 如 图 6-58 所 示 。 


paces UE dese a'bocki reply .Bhp .Dx 














HENA : 


1 
mut. t. 
p WEN: 
j CEE 
| WssE: 
| wsme: 


1 
|o BEAR: 








cam Lom 
1 ü 
ur 下 一 一 站 ee E 
la x | 
[eee [AEA i — . O6 acie 19€ K /3 Mr Maiede QI) — | 


图 6-58 回复 留言 页 面 效 果 
动态 功能 的 制作 步骤 如 下 。 
(1) 创建 replyphp 页 面 ， 并 单 击 “ 绑 定 ” 面 板 上 的 [地 按钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 进 行 如 下 设置 。 
D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 集 的 名 称 。 
2) 从 “连接 ”下 拉 列 表 杠 中， 选择 数据 源 连 接 对 象 gbook。 
3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 
4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 
5) 设置 “筛选 ”的 方法 为 : ID = URL 参数 ID. 
再 单 击 “ 确 定 ” 按 钮 后 残 完成 设 定 ， 如 图 6-59 Br. 






























































6-59 设置 “记录 集 ” 对 话 杠 

















(20 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 reply.php 网 页 的 适当 位 置 ， 如 图 6-60 所 示 。 


me VMipachelhtdocsVgbookVreplr. php 


nx 
T 






EDN 您 要 回复 留言 的 ID 号 是 | {Rs. ID} S 
er gsm: Hee o 
Ped ied BETT: : Bs. IPL 


Re content} 























HT 


: 客户 电话 : 010-12345678 
E GMT 8 40 40cm armomo 





一 一 一 <tr> <td> <table> <tr> <td> CERREN [À | : T86 x 4698» 128 K / 3 E^ Unicode (UIF-B)  - 
6-60 插入 绑 定 字段 全 reply.php 网 页 


(3) 在 本 页 面 中 添加 两 个 隐藏 区域 ， 一 个 为 redate， 用 来 设 定 回 复 时 间 ， 赋 值 等 于 <?php 
date default timezone set('Asia/Shanghai);echo date("Y-m-d h:1:s");?>; 另外 一 个 是 passid， 用 
来 决定 是 否 通过 审核 的 一 个 权限 ， 赋 值 为 0 时 ， 怠 自动 通过 审核 ， 如 图 6-61 所 示 。 








尾 性 
AI FS x eft 

ÍB (V) lai’ );echo date("T-m-d h:i:s");?2| 多 
EIE 





N] eren 
iB o 98 





图 6-61 设置 “隐藏 区域 ”两 个 字段 的 属性 


(40 单 击 “服务 器 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 染 音 中， 选择 “更 新 记录 ”命令 ， 
如 图 6-62 所 示 ， 用 于 根据 留言 内 容 对 数据 库 中 的 数据 进行 更 新 。 





+ 一 THRE. n 













重复 区 域 


记录 和 集 分 页 d 
显示 区 域 d 


显示 记录 计数 d 
动态 女 本 i 


HARR 
更 新 记录 
删除 记录 
动态 表单 元 素 > 
用 户 身 份 验证 > 
XSLT 转换 


编辑 服务 器 行为... 
新 建 服务 器 行为 ... 
获 职 更 多 服务 器 行为. .. 

























- 


6-62 选择 “更 新 记录 ”命令 















PHP 


(50 在 打开 的 “更 新 记录 ”的 对 话 框 中 ， 按 如 图 6-63 所 示 进 行 更 新 设置 。 





s EH: | forml 




















， 使用" PORN. ID TER EA AENEA ERE 

, subject * FORM. subject CR E d 

i content 从 FORM. content' GREEN =p 

LUN. b reply 获 职 值 作为 “ 交 本 

, 获取 值 作为 “日 期 

获取 值 作为 “日 期 
A UE 

'passid $us FORM. dns, ARHMBTEN WE 


(B: | FORM. ID v 
gem. | 整数 ~Me 
在 更 新 后 ， 转 到 : admin. php | 






































6-63 ”设置 “更 新 记录 ”对 话 框 
(6) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 这 样 束 完成 了 回复 留言 页 面 的 设置 。 


SAEC 删除 留言 页 面 


删除 留言 页 面 delbook.php， 其 功能 是 将 表单 中 的 记录 从 相应 的 数据 表 中 删除 。 页 面 设 计 
效果 如 图 6-64 所 示 ， 详 细 说 明 步 骤 如 下 。 














Qar- o- [gi (o sme thA GO S-i 
Hte an CECHI (D. 17 ghaak/delhoek. php?TEnl 


Tunt —— Bm AEREA ^o 311.0722 03:26:46 


mre | |] | tk 
Sa: ] | ENHBEZeDER | ju: 
EEE] | — EmA: (2011-07-12 
EAE Hima |o MESI: [127.0.0.1 
€wARTA: (test 

HE AREAS 


WEAF: 


EERW: | 过 是 回复 测试 


FAm t 000-1 2345878 
RR: o0:0-12)49578 


EFA :GESEMS EEEN 





ewed FETE RERNA 


6-64 ”删除 留言 负面 效果 


(1) 打开 delbook.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 [出 按钮 ， 在 弹出 的 选项 中 ， 选 择 
“记录 集 (但 询 )” 命 令 ， 在 弹出 的 “记录 集 ” 对 话 杠 中， 进行 如 下 设置 。 











QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 








第 6 章 CHAE ESI 








D 在 “名 称 ” 文 本 框 中 输入 Rs 作为 该 记录 和 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 象 gbook。 

3) 从 “表格 ”下 拉 列 表 杠 中， 选择 使 用 的 数据 库 表 对 象 为 gbook。 
4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

5) 设置 “筛选 ”的 方法 为 : ID = URL 参数 ID. 

再 单 击 “确定 ”按钮 后 就 完成 设 定 ， 如 图 6-65 rn. 















































6-65 设置 “记录 集 ” 对 话 框 


(2) 绑 定 记录 集 后 ， 再 将 记录 集 的 字段 插入 至 delbook.php 网 页 的 各 说 明文 字 后 面 ， 如 
图 6-66 所 示 。 

(3) 在 delbook.php 的 页 面 上 ， 单 击 “ 服 务 器 行为 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 删 除 记录 ”命令 ， 如 图 6-67 所 示 ， 用 于 对 数据 表 中 的 数据 进行 删除 操作 。 


局 C: wpachevht doesAgbookvdelbook. php -0x 


































































































首页 | 新 闻 动 态 | 信息 服务 | 信息 知识 | 信息 产业 | HAMD | #488 | 联系 我 们 
您 的 位 置 一 一 册 除 留言 现在 的 时 间 是 : gu 
! À sas: 
aede. AIR Ce OE CE ET DC NC RA S E- HeJ . 
| weNBSsmDeR R De: za 文档 类 型 : PHP 
留言 时 间 : |l[Rs.datel ERR 
BS : s. subject 3 - 
{Rs. content] ^ pr d 
留言 内 容 : c3 3 显示 区 域 上 
eus i 显示 记录 计数 , 
回复 内 容 : | {Rs. reply} u 动态 文本 
插入 记录 
更 新 记录 
m" 动态 表单 元 素 
ud n MN o REE S 用 尸身 份 验证 
: 客户 电话 : 010-12345678 ; XSLT 转换 
p : 编辑 服务 器 行为 
: 联系 人 : 李 先 生 ”联系 我 们 : | ~ 新 建 服务 器 行为... 
< Jill ^ ps 
body> ONES T86 x 469v 127 K / 3 P Unicode (UTF-8)) — | 获 职 更 多 服务 器 行为 ，， 
iva IM v. iJ ^ 
6-66 字段 插入 全 delbook.php 网 页 6-67 选择 “删除 记录 ”命令 


(40 打开 的 “删除 记录 ”对 话 框 中 ， 设 置 效 来 如 图 6-68 所 示 。 









PHP 








首先 检查 是 天 已 定 兴 变量: 
连接 : 

表格 : 

主键 列 : wv [v] 数值 

主键 值 : wv [ID 

册 除 后 ， 转 到 |: 


















































图 6-68 设置 “删除 记录 ”对 话 框 
(5) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 这 样 就 完成 了 删除 留言 页 面 的 设 定 。 


中 ”管理 系统 功能 的 测试 


留言 板 系 统 部 分 用 到 了 手写 代码 ， 特 别 是 留言 的 日 期 和 回复 日 期 ， 其 中 还 涉及 到 了 留言 
者 的 了 P 采 集 ， 为 了 检查 开发 系统 的 正确 性 ， 需 测试 留言 功能 的 执行 情况 。 


6.54 


具体 的 前 台 测 试 步骤 如 下 。 
(D 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http:/127.0.0.1/gbook/， 打 开 index.php 文件 ， 如 
图 6-69 所 示 。 
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6-60 ”首页 效果 








QL+Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





xí) aux) X00 EG) INA UO 


全国 下 
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Tio Wu 


Pium 


留言 板 管理 系统 建设 
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RENAE: Dinna 


MESH, B TSTeORT 


WEEE: 
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SP 81b: 00-1 2045678 
TER: 010-12545678 


EEL EE ë ERRM 


6-70 


(3) 开始 检测 留言 板 功能 ， 在 “留言 主题 ” 栏 中 填写 “开始 检测 留言 板 功 能 ”， 





留言 页 面 效 采 
在 “ 留 





言 内 容 ” 


栏 中 填写 “如 果 成 功 ，gbook 数据 表 中 将 添加 刚才 写 入 的 内 容 ”。 


填写 完 后 ， 单 击 


“提交 ” 投 钮 提交 ， 此 时 打开 index.php 页 耐 ， 可 以 看 到 多 了 一 个 刚 填写 的 数据 ， 如 图 6-71 


所 示 。 


Jeani 
Emo) depo) 


Wicrnzaft Interrncet Eznlüarrr 


EFO duo IAT Wihio 


QRuE- o- [gig d sme mx e 5 


Han G hetge // 127 0 0. 1/ ghaok/indaz php? 


felt RESET 


j| Agag 





HEBES | TriEEHES qo Hrasdell 


REOS S 20D LITE US AL38 


fono Heo ERRARE LODGE EE EE GERIE EAA 


:记录 19 2088 2 
D3 WNES: 
| HAAT: 
EmA: 


加 号 WEEE: 
2 mE: 


ETAK: 


FAMA * 000-12 458 TR. 
E : omega 


EFA lue EREN 
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*BINODIBUHLAEE HEAS: 
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mS IED LInosegms : 


3rratE da] EE TSE 
XBimamoolE AE EE: 

fuh s doookE SCR PEE IF E PA E 
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6-71 


问 数 据 表 中 添加 的 数据 












PHP 








WES 
(1) 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 http//127.0.0.1/gbook/admin login.php, #1 FF 
admin login.php 文件 ， 如 图 6-72 所 示 。 


(2) 在 网 页 的 表单 对 象 的 文本 框 及 密码 框 中 ， 输 入 用 户 名 及 密码 ， 输 入 完毕 ， 单 击 “ 登 
x" gH. 








Jd 后 台 管 理 -Nicrosoft Internet Explorer 
THF AmE EAV 收藏 以) IAM 帮助 0 


QAE- 加 -加 国名 s D 搜索 J4dEEx €) On « 

地 址 QD) Æ] http: //127. 0.0. l1/gbook/admin login. php pea 链接 O SnagIt Ey 
留言 板 管理 系统 后 台 
用 户 ， admin 
密码 ， admin| 


Eea 





























(MD Internet 


6-72 后台 管理 入 口 





G) 如 果 在 第 二 步 中 填写 的 登录 信息 是 错误 的 ， 浏 览 磊 融会 园 到 主页 面 index.php; WR 


输入 的 用 户 名 和 密码 都 正确 ， 则 进入 admin.php 页 面 。 在 这 里 输入 前 面 数据 库 设置 的 用 户 
admin 和 密码 admin 时 ， 转 到 admin.php 页 面 ， 如 图 6-73 所 示 。 








Ss 后 台 管 理 = 了 icroso ft Internet Explorer 

XO) EE EE) WO) IAM 和 帮助 Ht) 

QAE- O- nAIRE jux 6 3-3 BGL 
地 址 M) 8] http: //127. 0. 0. 1/gbook/admin. php 








所 输入 关键 词 搜索 wk 








首页 | 新 闻 动 态 1 信息 服务 | 信息 知识 | 信息 产业 | HAMN | 在 线 留言 | 联系 我 们 
你 的 位 置 : 管理 主页 面 


内 容 
如 果 成 功 ，gbook 数 据 表 中 将 添加 刚才 写 入 的 内 容 127.0.0.1 M ”回复 
Ws [BI 


Copytight(32011-2012 hbculture.com Inc.All rights reserved. 环 博 文化 版 权 所 有 D 


v 
p- 


开始 检测 留言 板 功 能 
test 这 是 测试 用 的 1270.0.1 





6-73 打开 的 留言 管理 页 面 
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m uoo —g e è ë p eiu E UN - 
GOG 809^ * - - - s EEEL : ran = | LE p7 EJ v1" 
Doo 5 ev - *: c E "" & 6 5 &B BD DUI i B p. m y 板 三 | 85 zt D 


(A) 选择 “删除 ”命令 ， 进 入 删除 页 面 delbook.phpp， 并 自动 将 删除 该 留言 信息 。 删 除 留 
言 后 返回 留言 管理 页 面 admin.php。 

(50 在 留言 管理 页 面 选择 “回复 ”命令 〈 本 次 测试 选择 编号 为 2 的 留言 进行 回复 )， 则 
进入 回复 页 面 replyphp， 如 图 6-74 所 示 。 








xa) Win Gon pwwo ING) don 
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ENEE: #MEMEEET 
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6-74 打开 的 回复 页 面 


(60 当 填 号 回复 内 容 “ 这 是 测试 回复 的 >， 并 单 击 “ 回 复 ” 按 钮 ， 将 成 功 回 复 。 
全 此 ， 完 成 了 网 站 留言 板 管理 系统 的 建设 ， 读 者 可 以 将 其 应 用 于 实际 网 站 的 建设 。 




















第 区 4 章 ”投票 管理 系统 


本 章 主要 将 以 手写 代码 的 形式 开发 一 个 投票 管理 系统 ， 一 个 投票 管理 系统 大 体 可 分 为 3 


个 模块 : 选 紧 恒 块 、 选 票 处 理 模 块 以 及 结 末 显示 模块 。 投 票 管理 系统 首先 给 出 选 栋 选 题 ， 即 
供 投票 者 选择 的 表单 对 象 ， 当 投票 者 单 击 选择 投票 按钮 后 ， 选 紧 处 理 梗 其 被 激活 ， 对 服务 器 
传送 过 来 的 数据 做 出 相应 的 处 理 ， 先 判断 用 户 选 择 的 是 哪 一 项 ， 把 相应 字段 的 值 加 1 ， 然 后 
对 效 据 进行 更 新 ， 最 后 将 络 东 显示 出 来 。 本 章 的 核心 在 于 开始 以 手写 代码 的 形式 实现 PHP 
页 面 的 各 种 功能 ， 真 正 提 高 谈 者 的 程序 编写 能 








MATIE E 


主要 掌握 以 下 知识 点 : 


(7 投票 管理 系统 站 点 的 设计 

O 投票 绾 理 系 统 数 据 库 的 规划 
O 计算 投票 的 方法 

© 防止 刷新 的 设置 





投票 管理 系统 


_ Section_ 


系统 的 整体 设计 规划 


改 票 管理 系统 可 以 分 为 3 个 部 分 的 页 面 内 容 ， 一 是 计算 投票 页 面 ， 二 是 显示 投票 结果 页 
面 ， 三 是 用 来 提供 选择 的 页 面 。 本 章 制 作 的 投票 管理 系统 总 共有 4 个 页 面 ， 页 面 的 功能 与 文 
件 名 称 如 表 7-1 所 示 。 














表 7-1 投票 管理 系统 网 页 设计 表 


需要 制作 的 主要 页 面 页 面 名 称 Jj 能 


开始 投票 页 面 访问 者 开始 进行 投票 的 页 面 
计算 投票 页 面 对 访问 者 提交 的 数据 进行 统计 并 向 数据 库 增加 数据 的 功能 页 而 


显示 投票 结果 页 面 voteok.php 显示 投票 选项 比例 和 总 显示 投票 的 最 终 效 果 页 面 
票 失 败 页 面 sorry.php 投票 失败 转 癌 的 页 面 


将 要 制作 的 投票 管理 系统 的 网 页 及 网 页 结构 如 图 7-1 所 示 。 




























投票 管理 系统 


计算 投票 页 面 显示 投票 结果 页 面 


sorry.php 


图 7-1 投票 管理 系统 网 页 结构 图 


2 页 面 设计 规划 : 


根据 介绍 的 投票 管理 系统 的 页 面 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 vote， 将 要 制 
作 的 投票 省 理 系 统 的 文件 夹 和 文件 如 图 7-2 所 示 。 





voteadd.php voteok.php 











ta 
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图 7-2 站 反 规 划 文 件 夹 和 文件 
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役 轩 管理 系统 的 页 面 共 4 个 ， 包 括 开始 投标 页面、 计算 投标 页面、 显示 投 时 结果 页 面 以 
及 投票 失败 页 面 。 计 算 投 票 页 面 voteadd.php 的 实现 方法 是 接收 vote.php 所 传递 过 来 的 参数 
后 执行 累加 的 功能 。 为 了 保证 投票 的 公正 性 ， 本 系统 根据 IP 地 址 的 唯一 性 ， 设 置 了 防止 页 
面 刷 靳 的 功能 。 开 始 投票 页 面 和 显示 投票 结束 页 面 的 设计 如 图 7-3 和 图 7-4 所 示 。 
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7-3 ”开始 投票 页 面 7-4 ”显示 投票 结果 页 面 





E 数据 库 设 计 与 连接 


本 市 主要 掌握 投票 官 理 系 统 数 据 库 的 连接 方法 。 投 票 管 理 系 统 的 数据 库 主要 用 来 存储 投 
昧 选项 和 投票 次 数 。 














vens 数据 库 设 i | 





发 票 管理 系统 需要 一 个 用 来 存储 投票 选项 和 投票 次 数 的 数据 表 vote 和 用 于 存储 用 户 IP 
地 址 的 数据 表 ip. 

制作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL”， 进 入 MySQL 数据 库 的 管理 面 
板 ， 如 图 7-5 所 示 。 

















(2) 单 击 工具 栏 的 Crate 〈 增 加 ) 按钮 ， 并 在 打开 的 下 拉 某 单 中 单 击 选择 “Database 
(数据 库 )” 命 令 ， 如 图 7-6 所 示 。 
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7-5 打开 MySQL 数据 库 管 理 界面 7-6 单 击 选 择 “DataBase” 命 令 


(3) 打开 “Create Database Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“vote”, 然后 再 单 击 Next 《下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 7-7 所 示 。 


Create Database Wizard 
Create Database 
Specify the name for a new database 
Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 





Database name vote] 





Register after creating 





7-7 输入 数据 库 的 名 称 “vote” 
(4) 设置 MySQL 数据 库 的 属性 设置 如 表 7-2 所 示 ， 连 接 设置 如 图 7-8 所 示 。 然 后 再 音 





击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 有 的 设置 。 


表 7-2 数据 库 属性 设置 
Host name localhost Port 3306 


User name root 


Password admin 
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Create Database Wizard 
Create Database 


Set connection properies for a new database 





Host name localhost 














User name 











Password 











Character Set Lise server settings 








Collation 














[ ]use tunneling 


Tunneling 
*; SSH tunneling HTTP tunneling 








图 7-8 连接 设置 
(5) 打开 新 建 数据 库 的 SQL 语句 提示 创建 数据 库 vote, Fifa Next (下 一 步 ) 按 
钮 ， 如 图 7-9 所 示 。 


Create Database Wizard 
Create Database 
Result SQL statement. Click the Finish button to create a new database. 


Result SOL statement:: 
CREATE DATABASE "vote'; 





如 有 | 





Click "Finish" to create the database. 





j Cancel 





图 7-9 完成 设置 
(6) 单 击 Finishn〈 完 成 ) 按钮 ， 打 开 注 册 数 据 库 的 设置 画面 ， 选 择 utf8 字符 集 及 人 徐 体 中 
文 版 的 GB2312 版 ， 其 他 的 保持 默认 值 ， 如 图 7-10 所 示 。 


Database Registration Info 








Display Options Host name localhost {v Port 3306 $ 
[© Directories 
fl Logs 

(f$ SSH Tunneling 
Ill HTTP Tunneling Database name 
Data Options 








User name 








Password 














Database alias vote on localhost 








Client charset utfg| v 














Font charset GB2312 CHARSET (Simplified Chinese characl w 














图 7-10 选择 简体 中 文 

















E EE S 


CI) 单 击 OK 确认 ) 按钮 ， 完 成 数据 库 vote PESE LE. 

数据 库 建 立 后 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 vote. 
ip。 建 立 数 据 库 后 ， 接 着 再 按 左 边 的 “Connect to Database. 〈 连 接 数 据 库 )” 图 标 总 ， 将 其 连 
接 上 。 这 两 张 数据 表 的 字段 结构 内 容 说 明 如 下 。 

CIO 建立 数据 库 vote 后 ， 用 局 标 右 键 单 击 选 择 “Table CERO" Am, ÆHF RA 
中 ， 单 击 选择 “New Table JIRO” ME, WK 7-11 所 示 。 





ir Create now table 


[P^ Create new database object 


g Execute query 


$5 Manage permissions 


SA Manager 2007 help system 


MySQL reference 





7-11 开始 建 数据 表 


(2) 数据 库 右 方 夯 面 会 出 现 新 建 数据 表 Table 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields (内 容 )”、“DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 
vote， 如 图 7-12 所 示 。 


Ss New Table — [vote on localhost] 


D Table |Fields | DDL 


Table Properties 
8 vote on localhost [vote] w 
Table name vote| 
c — E 


Storage Options 
学 Compile Storage engine MyISAM {v 
9) Show SQL help Row format DEFAULT v 
Restore default size | Min. rows 


^|. Max. rows 




















0 
0 
7 Auto increment value 0 
0 


z Average row length 








<>< >< >< ><> 








; Size for index key blocks 0 
- [C] Check sum [C] Delay key write 
[ ]Pack keys C] Temporary 





Character Sets | File Options | Merge Table Options | Federated Table Options 


Collation Default v 








7-12 输入 数据 表 名 vote 








PHP 
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(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 7-13 所 示 。 对 投票 系统 页 面 (?) 内 容 做 一 个 全 面 的 分 析 ， 设 计数 据 表 vote 的 字 
段 结构 如 表 7-3 所 示 。 


主题 编写 


表 7-3 投票 数据 表 vote 字段 结构 


| wmm | n | 5 
[m | vom | o | a’ 
[o | omes : 


e Table — [vote] — [vote on localhost] 


| [3 vote on localhost [vote v 


| EŞ vote 


- 


[a] Refresh 
| 学 Compile 
Qs Grants on table 
cea Print 
©) Show SQL help 
dh Table Editor options 
回 Restore default size 











g 





Tools 


Ei Truncate table 














Field Type | Size |Preci...| Mot... Default Comment 


INTEGER |11 0 Null 




















7-13 创建 的 vote 数据 表 


(4) 为 了 方便 后 面 系 统 开发 的 需要 ， 事 先 在 vote 数据 表 里 加 入 4 个 投票 的 数据 ， 单 击 
“Date《〈 数 据 )” 选 项 卡 ， 在 数据 表 中 手动 加 入 名 为 A~D 的 4 个 选择 模式 ， 如 图 7-14 所 示 。 


NE EE [vote] — 


| [3 vote on localhost [vote v 


| Ef) vete 


General 


ig] Refresh 

学 Compile 

Qs Grants on table 

caa Print 

©) Show SQL help 

d Table Editor options 
回 Restore default size 











g 





Tools 


E Truncate table 


A 





[vote on localhost] 














i Properties | Fields || Indices | Triggers | Data | Dependencies | DDL | 


IPEE Heka Ak aa 0 = E 


column 





Drag a column header here to group br that 




















| Grid View | Form View | Print Data 
Records fetched: 4/4 | | | JILIMIT. D, 1000 


图 7-14 输入 投票 选择 模式 
(50 创建 ip 数据 表 ， 用 于 限制 重复 投票 使 用 ， 输 入 数据 域名 称 以 及 设置 数据 域 位 的 相 





关 数 据 ， 如 表 7-4 及 图 7-15 所 示 。 











X 
主题 编号 
SERI ip HEHE 


ISES 
J 


Æ Table - [ip] - 


^l | Properties | Fields |Indices | Triggers | Data | Dependencies | DDL 
Field Name Field Ty... Size | Pre... | Not... Default Comment 


X 7-4 


字段 名 称 





ip 数据 表 字 段 结构 


voteip 


Object 





vote on localhost [vote v 














Ef ip v 





数据 库 创建 


以 及 插入 等 操作 


1.2.2 





在 Dreamweaver CS 5.5 中 创建 一 个 “投票 系统 


General = 


ig Refresh 
学 Compile 


e» Grants on table 


©) Show SQL help 

d Table Editor options 

加 Restore default size 
Tools 


E Truncate table 


"T 
完毕 ， 


o 


[vote on localhost] 





B 


E voteid VARCHAF 255 |0 Null 














图 7-15 创建 的 ip 数据 表 





对 于 本 系统 而 言 ， 痢 技术 是 如 何 用 手写 代码 的 形式 实现 数据 库 的 碍 询 


定义 vote 站 点 


定义 vote 站 点 | 


网 站 站 点 vote， 由 于 这 是 PHP 数据 库 


Zr 


Ph, DOC E ELA DC AERA AS des ESTEE ETE Ue 7-5 Pro. 


47-5 站 点 设置 的 基本 参数 
站 点 名 称 vote 
本 机 根 目录 C:\Apache\htdocs\vote 
测试 服务 需 CAApacheMtdocsV 
网 站 测试 地 址 http:;//localhost/vote/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All UsersVApplication DataMySQLIAMySQL Server 5.5MataWote 
管理 账号 / 密码 root / admin 
数据 库 名 称 vote 


创建 vote 站 点 具体 操作 步骤 如 下 。 


(1) 首先 在 C:\Apache\htdocs 路 径 下 建立 vote 文件 来， 如 图 7-16 所 示 ， 本 章 所 有 建立 
的 网 页 文件 都 将 放 在 该 文件 夹 下 。 


















7PHP-^ 


Canpachevhtdocs 
THFT 编辑 于】 SAV 收藏 以 ) IAM 大助 0) 
OFE- O- F| OLER DHR Em 





地 址 0) E C: apachevhtdocs 


«ges 








XE XPEXIES A 


mw] 重合 名 这 个 文件 到 
TE E: 
A 复制 这 个 文件 来 
Q 将 这 个 文件 夹 发 布 到 
Web D pholtyAdnin 


E IE MUT 
以 电子 邮件 形式 改 送 

2 Eie | E- 

x HERITIXE ip 


&]index. html 1 KB HTML X 


HUE 1 THR 





7-16 ”建立 站 点 文件 夹 vote 


出 
打开 “管理 站 点 ”对 


(2) 354] De aN CS 5.5， 和 选择 来 
“让 点 ”一 “管理 站 点 ” 
话 框 ， 如 图 7-17 所 示 。 

(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 
有 已 经 定义 的 站 点 。 单 击 右 边 的 “ 狐 建 ”按钮 ， 打 开 
“站 点 设置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ” vote. 

“本 地 站 点 文件 夹 ”. 

如 图 7-18 所 示 。 


靖 点 设置 对 旬 vote 








C:\Apache\htdocs\vote\。 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweaver 
包含 两 个 部 分 ; 可 在 其 中 存 展 和 处 理 文 件 的 计算 机 上 的 本 地 文件 
二 < 以 用 可 在 其 中 将 相同 文件 发 布 和 到 web 上 的 服务 器 上 的 远程 文件 来。 


站 点 通常 











2011-7-11 18:57 
2011-7-29 1T:42 
2011-7-28 15:36 
2011-T-T 22:04 
2011-7-9 8:00 
2011-86-15 9:41 
2011-T-4 9:35 
2011-T-30 18:20 
2011-85-30 15:30 
2011-T-11 18:48 
2011-8-1 19:09 
2004-11-20 15:18 

















7-17 


f& Rf EAE ERRAT Dreamweaver 3 A e ds Hi PEXECRU S ER 
站 点 名 称 : 
本 地 站 占 剖 件 来 ; | CApachelhtdocslvotel 5 


建立 vote 站 点 


并 单 击 “添加 服务 器 ”按钮 [由 ， 打 开 “ 基 本 >” 


7-18 


(40 单 击 列表 框 中 的 “服务 器 ”选项 ， 
选项 卡 ， 进 行 如 图 7-19 所 示 的 参数 设置 。 
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编辑 (E) 
复制 (P) 
HIER R) 

导出 (T) 





“管理 站 点 ”对 话 框 








票 党 理 系统 





“IRIRA”: vote. 
“连接 方法 ” 本地/ 网络 。 
«Husa X LIC": C:\Apache\htdocs\。 
“Web URL”: http:// localhost/ vote/. 


[. J-h-ér Ww: MAIO 


> 
EE = | wj] 
HER Bsasm[bo O ë 





p> ”高 级 设置 
连接 方法 :| 本 地 /网络 |» 
RA Brix 
Web URL: | http:// localhost/ vote] 








图 7-19 设置 “基本 ”选项 卡 
(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 。 单 击 “维护 同步 
信息 ” 复 选 按钮 ， 在 “服务 右 模 型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 来 表示 是 使 用 PHP JF 
发 的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 7-20 所 示 。 





站 点 设置 对 务 vote 


版 本 控制 
> 高 级 设置 [VI 维护 同步 信息 


O 保存 时 自动 将 净 件 上 传 到 服务 器 


O 自用 文件 取出 功能 
z Wi | 


MARR 


职称 | 








电子 邮件 地 址 : l 


测试 服务 器 
resnu [pema e] 





图 7-20 设置 “高 级 ”选项 卡 
(6) 蛙 击 “保存 ”按钮 ， 返 回 “ 服 务 占 ”设置 对 话 框 ， 再 单 击 选 择 “ 测 试 ” 复 选 按钮 ， 
如 图 7-21 所 示 。 












PHP 


站 点 设置 对 得 vote 


SE 您 将 在 此 位 置 选 择 学 载 web 上 的 页 和 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
版 本 控制 Internet 服务 提供 商 (ISP) 或 web SER. 


* ”高 级 设置 








注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完 成 此 步 又。 如 果 要 连接 到 | web 并 发 
布 页 面 ， 您 只 需 定义 一 个 远程 服务 器 即 可 。 





名 称 | 地 址 | 连接 | 远程 Wi | 
vote CiApachejhtdocs 本 地 /网络 [V M 








7-21 设置 服务 器 参数 


单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 
刚 所 设置 的 站 点 vote。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 枉 ， 这 样 束 完成 了 
Dreamweaver CS 5.5 测试 M 网 页 的 网 站 环境 设置 。 


设置 数据 库 连接 


完成 了 站 扣 的 定义 后 ， 接 下 来 就 是 投票 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 与 数据 库 的 





1.2.3 











连接 设置 如 下 。 
CD 将 光盘 中 设计 的 本 章 静 态 文 件 复制 到 站 点 文件 夹 下 ， 打 开 vote.php 投票 首页 ， 如 图 
7-22 所 示 。 


Dw | ewm -1(8— — Oow CEES 
ELIT abo CO Am PRm BAW ÉF KEC mae) Mihm 


EE MAS EE. Gm ux Wh LEAR e B © i 
ir -- a fat Hit NAF sharh : s , La 


rT 
4. ga 9) Tee SEU SEE 


PHP 投 票 系统 


公平 2E 调查 分 析 


| MENU + + ERAT RE 


: Pow 
[k]fy qQ nu  -wwxaape ce K/ M Weed AD) 


[Om] Wm x 0 — v [Æ v mz dmuuugmo| O 
ood mmx 加 E "Qo Bem 


: | > 
E 1 个 本 地 项目 镇 渤 中 , $E) 





7-22 打开 网 站 首页 
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(2) ARWR Ef] "ELIT — ARE $m. HA AE” DM. YE CUNG 
库 ” 面 板 ， 单 击 选 择 “+” 投 钮 ， 并 在 打开 的 染 单 中 选择 “MySQL 连接 ”命令 ， 如 图 7-23 
PZR o 








»1. OWuEGEPRSUSR 站 点 。 
zo 选择 一 种 立 挡 类 型 。 
w 3. 设置 站 点 的 出 二 服 车 器 。 
4 ELEK + 按钮 创建 连接 。 


图 7-23 ”选择 MySQL 连接 


(3) Æ “MySQL 连接” 对话 框 中 ， 输 入 “连接 名 称 ” 为 vote, "MySQL 服务 器 ”名 为 
localhost, “用户 名 ”为 foot， 密 但 为 admin， 如 图 7-24a 所 示 。 选 择 所 要 建立 连接 的 数据 库 
名 称 ， 可 以 单 击 “ 选 取 ” 按 钮 浏览 MySQL 服务 左上 的 所 有 数据 库 。 选 择 刚 建立 的 范例 数据 
FÉ vote， 上 其 体 的 设置 内 容 如 图 7-24b Bras. 


NySQL Erf 


zo 
es. Red 
sa: 
nx. 


performance schemaold 
we 








图 7-24 WE MySQL 连接 参数 


(4) Ah MR” A, MAS MySQL 数据 库 的 连接 是 否 正 硝 ， 如 果 正 确 则 会 出 一 个 
WME, WE 7-25 所 示 ， 这 表示 数据 库 连 接 人 设置 成 功 。 








f zr 


连接 铭 称 : 
MySQL 服务 器 : 





7-25 设置 成 功 


单 击 “ 确 定 ” 投 钮 ， 返 回 编辑 页 面 ， 在 “数据 库 ” 面 板 中 则 显示 绑 定 过 来 的 数据 库 ， 如 
图 7-26 所 示 。 





数据 库 eme | 服务 器 行为 | = 
+ 一 TEEN. PHP 会 
日 vote 
E-Eà MEn 
"e TE enn 
日 m vota 


Lo -W ID (nt 11 必需 的 ) 
A Zn item (varchar 50 必需 的 ) 
Pr zs vote (int 20 JB 

B) X 视图 

bd. Nus 


7-26 ” 绑 定 的 数据 库 





投票 管理 系统 页 面 设 计 


在 投票 管理 系统 中 ， 需 要 重点 设计 的 页 面 是 开始 投票 页 面 vote.php 和 投票 结果 页 面 
voteok.php。 计 算 投票 页 面 voteadd.php 是 一 个 动态 页 面 ， 没 有 相应 的 静态 页 面 效 果 ， 只 有 累 
加 投票 次 数 的 功能 





/.3.1 开始 投 RAL 设计 


开始 投票 页 面 vote.php 主要 是 用 来 显示 投票 的 主题 和 投票 的 内 容 ， 让 用 户 进行 投票 ， 然 








后 传递 到 voteadd.php 页 面 进行 计算 。 

许 细 的 操作 步骤 如 下 。 

d) 打开 刚 创 建 的 vote.php 页 面 ， 输 入 网 页 标题 “开始 投票 页 面 ” 执行 采 单 “文件 ” 
一 “保存 ”命令 ， 将 网 页 保存 。 

(2) 在 刚 创建 背景 图 像 的 单元 格 中 ， 执 行 末 单 “插入 记录 ”一 “表单 ”一 “表单 ” 合 
令 ， 再 执行 染 单 “插入 记录 ”一 “表格 ”命令 ， 在 表 蛙 中 插入 一 个 3 行 2 列 的 表格 ， 并 在 
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Cr LA-EESS 





dbHASTTCR MAWR” — “RE” — “Awk”, 插入 一 个 单 选 按钮 ， 然 后 在 “ 属 
性 ”面板 中 选择 单 选 按钮 ， 将 它 命 名 为 ID， 如 图 7-27 所 示 。 





ken 
r7) es WU 0 初始 状态 OB C at (c) > 
OREP (0 





7-27 设置 “ 单 选 按钮 ”名 称 
(3) 执行 菜单 “插入 记录 ”一 “表单 ”一 “按钮 ”命令 ， 插 入 两 个 按钮 。 一 个 是 用 来 提 
区 表单 的 按钮 ， 命 名 为 “投票 ”， 男 外 一 个 是 用 来 查看 投票 结果 的 按钮 ， 命 名 为 “查看 ”。 效 
果 如 图 7-28 所 示 。 











bc C:\ipache\htdocs\vote\vote. php* STEX 


PHP 投 票 系统 
公平 ”公正 WE 分 析 


:请 你 投票 + t t 本 投票 只 可 投票 一 次 


3 7596 (335) 
I4. 8696 (287) 
* 

4 [Iv 3 8 


v 


D (fora " "aio <tr> <td> Qabel?Knput) [k] Q 100€ — «661 x 4T2v 42K / 1 15 EXE es - 
图 7-28 插入 两 个 按钮 效果 图 


(4) 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 输 入 设 定 值 ， 如 图 7-29 Bras. 











名 称 : Rsvote | 


连接 : vote v 
DOS v 











列 : 9 em O 选 定 的 : 














URL EMI 





排序 : | 无 











7-29 ”设置 “记录 和 集 ” 对 话 框 








^ PHP+ QL*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





(5) 绑 定 记录 集 后 ， 将 记录 集中 的 字段 插入 全 vote.php 网 页 的 适当 位 置 ， 如 图 7-30 所 示 。 


| 7595 (335) 
UNE = 
' 你 投 的 选项 是 : 

Q [Revate.item?| 


一 





图 7-30 ”记录 集 的 字段 插入 至 vote.php 网 页 
(6) 单 击 “ 单 选 按钮 ” 将 字段 ID 绑 定 到 单 选 按钮 上 ， 绑 定 后 在 “ 单 选 按钮 ”的 属性 面 
板 中 的 “ 选 定 值 ” 中 添加 了 插入 ID 字段 的 相应 代码 为 <?php echo $row_Rsvote[TD']; ?>， 如 
图 7-31a. b 所 示 。 








at: 
HEB: [Hp echo Sron Ravotel IN 1; 97 





单 选 按钮 姐 : "ID" 在 RE “forni” v 
选 职 值 等 于 : <?php echo $row Rsvote[' ID ] P4 














b) 
图 7-31 插入 字段 到 单 选 按钮 
CD 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 命令 ， 单 击 vote.php 页 面 中 的 表格 ， 如 网 7-32 
所 示 。 





TS esas E—9— ————— — $$ RP] M ss i 
你 控 的 选项 是 ， 


1 
1 
| [S eee-E | 
| 


TT TT TT 


图 7-32 选择 要 重复 的 区 域 


(8) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选 
$E "ED BU sp, HA] 7-33a 所 示 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 一 页 显示 
Rsvote 记录 和 集中 的 所 有 记录 ， 如 图 7-33b 所 示 。 
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公平 2E WE 分析 


: MPRA 1 4 EBERENBE-II I | EEEE 


[; senimG*. 
EL. EERSNSWIN, 


3 i E uM MI 
lr ala trii ifr | P bala ars  [À AP OQ om — 206543 s Bde X3 E LES deed ATEA | 
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cx &EmcEU vE | 








图 7-33 设置 “重复 区 域 ” 对 话 框 
(9) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 ， 如 图 7-34 所 示 。 


T C:\Apache\htdocs\vote\vote. php -0x 
ETA vote. php 














公平 ”公正 WE E 


:请 你 投票 + + 本 投票 只 可 投票 一 次 


: 7596 (335) 

lik R = 8636 (287) p 
HE BE 
|O leweiem | 





| : 
<body> «table? <tr> <td> <form#forml > <table> [À | mq 661 x 410v 43 K / 1 b Unicode (UTF-8) — - 
V M 7 
图 7-34 设置 重复 后 的 效果 


(10) 在 vote.php 页 面 中 ， 将 鼠标 放 在 表格 中 ， 在 “标签 选择 右 ” 上 单 击 <form> 标 签 ， 
并 在 “属性 ”面板 设置 表单 <form1l> 的 “动作 ”为 设置 投票 数据 增加 的 页 面 voteadd.php。“ 方 
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ik" y POST. Auk 7-35 所 示 。 


























尾 性 
[| 表单 ID 动作 voteadd. php | (o 目标 (7) v 类 [C0) 无 
A [formi 方法 |POST v 编码 类 型 v 

















图 7-35 设置 表单 动作 

重点 说 了 明 : PHP $_GET 变量 和 $_POST XE. 

1) $ GET € €. $ GET 变量 是 一 个 数组 ， 内 容 是 由 HTTP GET 方法 发 送 的 变量 名 称 
和 值 。$_GET 变量 用 于 收集 来 自 method="get" kÆ Fii. AA GET 方法 的 表单 发 
送 的 信息 ， 对 任何 人 都 是 可 见 的 (会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送 的 信息 量 也 有 限 
制 (最 多 100 个 字符 ) 。 在 使 用 $_GET 变量 时 ， 所 有 的 变量 名 和 值 都 会 显示 在 URL 
中 。 所 以 ， 在 发 送 密码 或 其 他 敏感 信息 时 ， 不 应 该 使 用 这 个 方法 。 不 过 ， 正 因为 变量 显示 在 
URL 中 ， 因 此 可 以 在 收藏 夹 中 收藏 该 页 面 。 在 某 些 情况 下 ， 这 是 很 有 用 的 。 

2) $_POST € €. $_POST 变量 是 一 个 数组 ， 内 容 是 由 HTTP POST 方法 发 送 的 变量 
名 称 和 值 。$_ POST 变量 用 于 收集 来 自 method="post" 的 表单 中 的 值 。 从 带 有 POST 方法 
的 表单 发 送 的 信息 对 任何 人 都 是 不 可 见 的 (不 会 显示 在 浏览 器 的 地 址 栏 ) ， 并 且 对 发 送信 息 
的 量 也 没有 限制 。 

这 里 顺便 提 一 下 表单 的 验证 问题 ， 应 该 在 任何 时 候 对 用 户 输 入 可 以 进行 验证 。 客 户 端 的 
验证 速度 更 快 ， 并 且 可 以 减轻 服务 器 的 负载 。 但 任何 一 个 
流量 很 高 以 至 于 不 得 不 担心 服务 器 资源 的 站 点 ， 有 必要 担 E reens = 


属性 | 行当 | 标签 Gnput? 






心 站 点 的 安全 性 。 如 果 表 单 访 问 的 是 数据 库 ， 就 非常 有 必 sea 

要 采用 服务 器 端的 验证 。 在 服务 器 验证 表单 的 一 种 好 的 方 ok 
—-— 恢 香 蛮 换 图 像 

式 是 把 表单 传 给 它 自 己 ， 而 不 是 跳 转 到 不 同 的 页 面 。 这 样 打开 浏览 器 窗口 


用 户 就 可 以 在 同一 张 表 单 页 面 得 到 错误 信息 ， 用 户 也 就 更 
容易 发 现 错误 了 。 

(11) 单 击 页 面 中 的 “查看 ”按钮 ， 选 择 “ 标 签 | 
(input)” 面板 ， 单 击 “ 行 为 ”面板 下 的 外 按钮 ， 在 弹出 oe 
的 菜单 中 选择 “ 转 到 URL” 命 令 ， 如 图 7-36 所 示 。 

(12) 打开 的 “ 转 到 URL” 对 话 框 ， 在 URL 文本 框 
中 输入 要 转 到 的 文件 voteok.php， 如 图 7-37 所 示 ， 然 后 单 
击 “ 确 定 ” 按 钮 ， 完 成 “ 转 到 URL” 设 置 。 























本 地 视图 v 


图 7-36 ”选择 “ 转 到 URL” 命 令 








poc 











: |voteok. php | 








图 7-37 输入 “ 转 到 URL” 的 文件 地 址 

















计算 iy mii 





计算 投票 页 面 voteadd.php， 主 要 方法 是 接收 vote.php 所 传递 过 来 的 参数 ， 然 后 再 进行 四 
加 计算 。 计 算 投 票 页 面 voteadd.php 只 用 于 后 台 计 算 用 ， 希望 投票 者 在 成 功 投 票 之 后 转 到 投 
票 结 果 页 面 voteok.php， 只 要 加 入 代码 header("location:voteok.php");$] voteadd.php 页 面 束 可 











以 完成 对 voteadd.php 页 面 的 制作 。 本 小 节 核 心 代码 如 下 : 


«meta http-equiv-"Content- Type" content-" text/html; charset-utf-8" /> 
<?php 
if (empty($_POST['ID'])){ 
echo "您 没 选择 投票 的 项 目 "; 
exit(0); 
HM/ 判 断 是 否 选 择 了 人 返 网 标的 选项 
else 


{ 





$ID-strval$ POST['ID']); 
/赋值 D 变量 为 上 一 页 传递 过 来 的 ID 值 


"on "on 


$conn = mysql connect("localhost","root"," admin"); 
/建立 数据 库 连 接 
if (!$conn) 
{ 
die( 数 据 库 连接 出 错 :' . mysql_errorO); 
j 
/如 末 数 据 库 连接 出 错 ， 显 示 错 误 


mysql_select_db("vote", $conn); 


/查询 vote 数据 


mysql query("UPDATE vote SET vote = vote + 1 WHERE ID = ".$ID.""); 


/根据 ID 更 新 数 表 vote， 并 目 动 加 一 


mysql close($conn); 


header("location:voteok.php ); 
// 转 到 voteok.php 
} 


重点 提示 : 
UPDATE 语句 用 于 在 数据 库 表 中 修改 数据 
语法 

UPDATE table name 


SET column name - new. value 


WHERE column name = some value 





HEB SQL 对 大 小 写 不 敏感 ，UPDATE 5 update 等 效 。 
为 了 让 PHP 执行 上 面 的 语句 ， 必 须 使 用 mysql_query( )FR Ze 


该 函数 用 于 向 SQL XE 
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接 发 送 查 询 和 命令 。 





如 果 手 写 代 码 感 觉 到 困难 ， 请 打开 第 2 章 对 PHP 和 MySQL 数据 库 的 操作 章节 ， 进 行 详 
细 的 对 照应 用 。 在 手写 代码 的 时 候 切 勿 心烦 ， 只 有 细心 地 写 好 每 一 行 代码 ， 方 可 以 实现 其 功 


fE FUSAK hi o 


O SGRBERÁAURXEUET 


显示 投票 结果 页 面 voteok.php 主要 是 用 来 显示 投票 总 数 结果 和 各 投票 的 比例 结果 ， 静 态 
页 面 设 计 效 果 如 图 7-38 所 示 。 














b C: XApache*lht docs'*vote'*voteok. php* -= 口 X 


^ 





k]é) Q 100€ v615 x 292v 5 K / 1 ^ Unicode (UIF-5) — 
图 7-38 显示 结果 页 面 设计 效果 


COD 单 击 “应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 国 按钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 (查询 )” 命 令 ， 在 打开 的 “记录 集 ”对 话 框 中 ， 设 置 如 图 7-39 所 示 。 








7-39 ”设置 “记录 和 集 ” 对 话 框 


(20 再 次 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 办 按钮 ， 接 着 在 弹出 的 菜单 
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中 ， 选 择 “ 记 录 集 (人 查询)” 命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 局 级 ”按钮 ， 进 
入 高 级 编辑 窗口 ， 并 在 SQL 对 话 框 中 加 入 以 下 代码 : 

SELECT sum(vote) as sum 

/选择 vote EGET VERTES, BÉ sum() 用 于 计算 总 值 


FROM vote 
// 从 数据 表 vote 中 取出 数据 


如 图 7-40 所 示 。 





: Esl 








: [vote 








: SELECT sum(vote) as sum 
vote 














添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


预存 过 程 








7-40 ”设置 “记录 和 集 ” 对 话 框 


(3) 早 击 “人 确定” 按钮， 完成 记录 集 的 设置 。 绑 定 记 录 集 后 ， 将 记录 集中 的 字段 插入 到 
voteok.php 网 页 中 的 适当 位 置 ， 如 图 7-41 Bran. 


四 C:\Apache\htdocs\vote\voteok. php 


: em Enc sum}% {Rs.vote) 票 数 | : 


| 国 | 


& A 
body? <table> <tr> <td> <form... > IR | 584 x 289v 6 K / 1 $^ Unicode (UTF-8) 





7-41 字段 的 插入 全 voteok.php 


(4) 单 击 四 垣 按钮 ， 进 入 “代码 ”视图 编辑 页 面 ， 在 “代码 ”视图 编辑 页 面 中 找到 如 
下 代码 : 















PHP-* 


<?php echo $row. Rs['vote']; ?»/«?php echo $row. Rs1['sum']; ?> 


/相应 百分比 的 代码 


按 下 面 步 又 修改 此 段 代 人 码 。 
D 去 控 “/” 前 面 的 ?> 的 “/” 和 和 后面 的 <?php echo, AIT: 


<?php echo $row. Rs['vote']/ $row. Rs1['sum'] ?> 

2) 把 <?php echo 和 多 > 之 间 的 代码 用 〈) 把 它 给 括 上 ， 得 到 代 体 : 
<?php echo ($row_Rs['vote']/$row_Rs1['sum'])?>% 

3) 在 代码 后 面 加 入 *100， 得 到 代码 : 
<?php echo ($row. Rs['vote']/$row. Rs1['sum!]) *100?» 9c 


4) 在 代码 前 面 加 入 round， 在 *100 前 面 加 入 小 数 点 保留 位 数 4， 并 用 《〈) 括 上 ， 得 到 代 
fi: 
<?php echo round(($row. Rs['vote']/5row. Rs1['sum']),4)*100?* 96 
(5) 代码 修改 之 后 ， 因 为 控制 网 页 中 的 长 度 也 是 用 到 这 上段 代码 ， 所 以 将 这 段 代 但 进行 复 
制 ， 然 后 再 单 击 四 | 按钮， 切换 到 “代码 ”窗口 ， 选 择 <img> 中 的 width 的 值 将 其 代码 进行 业 
贴 ， 因 为 在 图 案 中 没有 用 到 小 数 点 的 设置 ， 所 以 将 代码 前 面 round 和 保留 位 数 4 删除 ， 得 到 
代码 为 : 


width="<?php echo round(($row. Rs['vote']/5row. Rs1['sum']),4)*100?» " 


这 样 ， 图 像 就 可 以 根据 比例 的 大 小 进行 宽度 的 缩放 ， 设 置 如 图 7-42 所 示 。 

















To] C: A&pache'ht docsNvote'*voteok. php = EIX 


a: vote.php T 
— LI Lu Uuciriilu1- PUS ci UII-— ^ 
83 «table wvidthsz"75$" borders"l" align="center" cellpaddings"0" E 


cellspacing="0" bordercolor="bl8a02" bgcolor="fff2bb"> 
<tr> 
<td height="20" colspan="3"><span class=" STYLE1l">&nbsp; <span 
clas3="STYLE6"> 投 票 结果 < /sp an></span></td 
LACES 
<tr> 
«td width="18$" height="25"><label><span classs"STYLE3"» 
&nbsp: <?php echo $row Rs['iten']; ?-«/span»-/label»«/td-» 
<td width-"495"5-&nbsp:czimqg src-"images/bar.qgif'" 
| height-"13" /> 











ll 


«span classs"STYLE3"- 
<?php echo round(($row Rs['vote']/$row Rsl['sum']),4)*100?-$ — 
«/span»«/td» 
«td width-z"335$" class=" STYLE3">&nbsp; <?php echo $row Rs['vote 
(3: 2 -3X!& mbsp; -td 


|< 





<form. . . > <table> <tr> «td» mg? 5 K # 1 f^ Unicode (UTF-8) 





图 7-42 设置 图 像 的 缩放 


(6) 单 击 [ 设计 | 榨 钮 ， 回 到 “设计 ”编辑 窗口 ， 加 入 “服务 器 行为 ”面板 中 “重复 区 
域 ” 的 命令 ， 选 择 voteok.php 页 面 中 需要 重复 的 表格 ， 如 图 7-43 所 示 。 
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投票 管理 系统 





T) C: XApache*ht docs\vote\voteok. php emp 
"nat vote. php 


7596 (351) = 
49% (170) = 


投票 结果 


| 投票 结果 | 
die [9g — — eso 





able»)? label? <span... > (R |d) Q (100 v584 x 289v 5 K / 1 $| Unicode (VIF-B) : 





图 7-43 ”选择 要 重复 的 区 域 
CI) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 选 
择 “ 重 复 区 域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 框 中 ， 设 定 显 示 Rs 记录 集中 的 所 有 记 
ok, ll 7-44 所 示 。 














7-44 设置 “重复 区 域 ” 对 话 框 


(8) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 会 发 现 先 前 所 选取 要 重复 的 区 域 左 上 角 出 现 了 一 
个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

(9) 单 击 页 面 中 的 “返回 ”按钮 ， 选 择 “ 标 签 (input)” 和 面板 ， 再 单 击 “ 行 为 ”面板 上 
的 四 按钮 ， 在 弹出 的 菜单 中 选择 “ 转 到 URL” 选 项 ， 在 打开 的 “ 转 到 URL” 对 话 框 中 的 
URL 文本 框 输入 要 转 到 的 文件 “vote.php” 如 图 7-45 所 示 。 

















打开 在 : Eann 


URL: wote. php Bit... 





7-45 输入 “ 转 到 URL” 的 文件 地 址 
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(100 单 击 “确定 ”按钮 ， 完 成 显示 投票 结 琳 页面 voteok.php 的 设置 。 测 试 浏览 效 末 如 图 
7-46 所 示 。 


A 投票 主页 面 ~ Nicrosoft Internet Explorer DER) 
THFT AEE SEM KRAO IA) E0 [7 


QAER- O-iX(at mk jux 四 | 办- Ema 
Htc 0) 4] http: //127.0.0. 1/vote/voteok. php —wo ceux Eea 链接 Qs 对 











图 7-46 显示 投票 结果 页 面 的 效果 


757 防止 页 面 刷新 设计 





一 个 投票 管理 系统 要 求 公 平 、 公 正 的 投票 ， 不 允许 进行 多 次 投票 ， 所 以 在 设计 投票 开始 


系统 时 ， 有 必要 加 入 防止 页 面 刷新 的 功能 。 

实现 该 功能 的 详细 操作 步骤 如 下 。 

(1) 打开 开始 投票 页 面 vote.php， 把 鼠标 放 在 表单 中 ， 执 行 菜单 “搬入 记录 ”一 “ 表 
单 ” 一 “隐藏 域 ”命令 ， 插 入 一 个 隐藏 字 上 段 voteip。 

(2) 单 击 隐藏 域 噶 图 标 ， 打 开 “ 属 性 ”面板 。 设 置 隐藏 域 的 值 为 <?php echo $ SERVER 
[REMOTE ADDR];?». 








/取得 用 户 IP 地 址 
如 图 7-47 所 示 。 
尾 性 = 
[NJ Fes [x Eh 
iB e) 多 


7-47 RA “KRE” (H 





(3) 将 实现 防止 刷新 的 程序 放 到 voteadd.php 页 面 里 面 ， 打 开 前 面 制 作 的 计算 投票 页 面 
voteadd.php， 在 相应 的 位 置 加 入 代码 ， 如 图 7-48 Dra» 

















AEG) 编辑 (EF) 查看 (Y) HA (OE ”格式 (0) 命令 ([C) xc) 窗口 ARH 
[A docs*vote'voteadd. php 
[代码 | dB | 设计 | | 实时 代码 pw A 








Dw | eim | [B3 Oc CEEB) 





Ł 一 TRH: PP 





i G D C qi: file:///C|/Apache/htdoi 


L4 
v 


Pu 


你 


M UE e 


A s 
ue x 


om ip where voteid-'".$voteip."''"" 





i: 
& 


$ir 
// 如 果 值 为 真 ， 说 明 数 据 库 中 有 ?地 址 ， 已 经 投 过 村 


若 要 在 该 页 面 上 使 用 动态 数据 : 
1. 


2. 
3. 
4. 


请 为 该 文件 创建 一 个 站 点 。 
选择 一 种 立 档 类 型 。 
设置 站 点 的 测试 服务 器 。 
ENS G) 按钮 并 选择 记 














: 


e vote 


司 || 本 地 视图 区 





roteok. p. hp 


query ("INSERT INTO ip (voteid) VALUES ('".$voteip."')" 
y^ 只 有 则 将 ip 地 址 插入 到 ip 数 据 表 中 


« E f ui 





2 K/ 1 f? Unicode (UTF-8) 





if (enpty G- POIL ID ])){ 
me 没 选择 投票 的 项 目 "; 


H 1A ic TERRAN 
else 








图 7-48 加 入 防止 刷新 的 代码 


具体 的 代码 分 析 如 下 : 


$voteip-strval($ POST['voteip']); 
/赋值 变量 voteip 为 上 一 页 传递 过 来 的 voteip fH 


$con = mysql_connect("localhost","root","admin"); 
/建立 数据 库 连 接 
if (!$con) 

{ 

die( 数 据 库 连接 出 错 :". mysql. error0); 

j 


// 如 果 数 据 库 连 接 出 错 ， 显 示 错 误 


mysql select. db("vote", $con); 

/得 询 vote 数据 库 

$sql=mysql_query("select * from ip where voteid="".$voteip.""); 
/以 voteid=voteip 为 条 件 查 询 数 据 表 ip 
$info2mysql fetch, array(S$sql); 

/从 结 末 集中 取得 一 行 作为 关联 数组 info 

if($info==true) 
URENA, HHA EPA IP hk, CARIK 


{ 


j 





header("location:sorry.php"); 
// 转 到 voteok.php 
exit; 


else 


{ 


mysql_query("INSERT INTO ip (voteid) VALUES ('".$voteip.")"); 





header("location:sorry.php"): Un © | 山 个 Ti E eg | Er] 
n 


Connections 
images 
mdb 


i 3 sorry. php 
Lh vote.php 


voteadd. php 


o voteok. php 





T ^ 
J Mx 


a 
ZA 
MÀ 


o 
-—. 






IPHP+ 
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// 如 果 没 有 则 将 ip 地 址 插入 到 ip 数据 表 中 
} 


mysql close($con); 


(4) 完成 防止 页 面 刷新 设置 。 当 用 户 再 次 投票 时 ， 系 统 可 以 根据 IP 的 唯一 性 进行 判断 。 当 
用 户 再 次 投票 的 时 候 ， 将 转 到 投票 失败 页 面 sorryphp，sorry.php 页 面 设计 如 图 7-49 所 示 。 
FEAE - icrosoft Internet Explorer 
ftc) RED 查看 0) RR IAT 帮助 00 
GEE- O- NEO Ps TER 6 2-LGL 
Ea: 13 [d] http: //127. 0.0. L/vote/zorry. php v EJ 931 Hs Qni p 














图 7-49 投票 失败 页 面 效果 











在 sorry.php 页 面 有 两 个 页 面 链接 ,“ 回 主页 面 ” 链 接 到 votephp. “查看 结果 ”链接 到 
voteok.php. 





投票 管理 系统 测试 


妇 票 管理 系统 设计 完成 以 后 ， 可 以 对 设计 的 系统 进行 测试 ， 按 下 (F12) 键 或 打开 IE 浏 
WASHA http://127.0.0.1/ vote/vote.php， 即 可 开始 进行 测试 。 测 试 步 骤 如 下 。 

(1) 打开 Dreamweaver 中 的 vote.php 文件 ， 按 下 (F12) 键 或 打开 IEhttp://127.0.0.1/vote/ 
vote.php， 即 看 到 开始 投票 页 面 效 果 ， 如 图 7-50 所 示 。 





ZAR ERE 一 Nicrozoft Intersst Explorer f fix 

TH) ao GE Mao IAT Sho dr 

Qm: 2 |a On tem e Um 

ig OH LN] euge rt gho -A RNE Elm uu Gro pr 
* 





PHP 投 票 系统 
公平 ”公正 WE 分 析 





UMREURI + + EXERCITIIS 


HIE E. 
QO A 
$ B 
O D 


(8X) (885 


Cesyright B 2011 Halise cea Ias ALl ripi rarervaed HETE ERAN 


DEG 8 | -] È urm E 


图 7-50 打开 的 开始 投票 页 








投票 管理 系统 


(2) 不 选择 任何 选项 ， 


单 击 “ 投 票 ”按钮 ， 则 打开 提示 “您 
7-51 所 示 。 


您 没 选择 投票 的 项 目 "， 如 疼 


Jd http://1271. 0. 0. 1/vate/voteadd. php 


Nicrosoft Int... EBR) 
TH Sen EEM KE ITAM) TR)OD AY 
om- O- x 


i (5 sm TRR 6 0- 9c 
Hr m) #) http: //127.0.0. 1/vote/voteadd. php 


您 没 选择 投票 的 项 目 














OW We Oa 加 





M Internet 
图 7-51 “您 没 选 择 投 票 的 项 目 ” 错 误 提 示 
(3) 单 击 投票 项 “ 单 选 按钮 ”项 中 的 其 中 一 项 ， 再 单 击 “ 投 票 ” 投 钮 ， 开 始 投票 。 
(4) 单 击 “ 投 票 ” 按 钮 后 ， 打 开 的 页 面 不 是 voteadd.php， 因 为 voteadd.php 只 是 计算 投 


票数 的 一 个 统计 数学 页面， 打开 的 页 和 面 是 显示 投票 结果 页 和 面 voteok.php，voteok.php 页面 是 
voteadd.php 转 过 来 的 一 个 页 面 ， 效 果 如 图 7-52 Bras» 























A 投票 主页 面 - Nicrosoft Internet Explorer 
TFT SHE SA0 收藏 IAM 帮助 0 


QAE- O- NAGAR wx e 


内- e BL 
地 址 0) 


< 输入 关键 词 搜索 MERA dm Osun (e 








æ http://12T.0. 0. 1/vote/voteok. php 





二 一 3448% 
20.69% 6 票数 
31.0396 9 票数 
13.79% 4 票数 





7-52 ”显示 投票 结果 页 面 效 果 
(5) 单 击 “ 返 回 ” 按 钮 ， 回 到 投票 页 面 vote.php "P. 
(6) 当 用 户 再 次 投票 时 ， 将 打开 投票 失败 页 耐 Sorry.php。 


d m-xw - 





| BW Internet Explorer 


THEO) RAD E GMa IAT WROD 


GKE- O NEG OR ttr 6 [DC mc 
HBIE C) AE] http://127.0.0. lvetefserry pip —— —5 cw M EJAN HE Qsan pr 
HFE, PERI—HAET , WTESHAA! 


BEND HESR 











aD Internat 


图 7-53 ”提示 已 经 投票 
22 EH 


经 过 上 面 的 测试 ， 说 明 该 管理 投票 系统 的 所 有 功能 已 经 开发 完毕 。 用 户 可 以 根据 需要 修 
改 投票 的 选择 项 ， 经 过 修改 后 的 投票 系统 可 以 适用 于 任何 大 型 网 站 的 开发 与 建设 。 














党 8 = BBS 论坛 管理 系统 


BBS (Bulletin Board Service， 公 告 牌 服务 〉 是 一 种 基于 Internet 的 信息 服务 系统 。 它 提 
供 了 公共 电子 白板 ， 每 个 用 户 都 可 以 在 上 面 发 布 信息 或 提出 看 法 。 本 章 将 学 习 使 用 PHP K 
Jj BBS 论坛 的 开发 方法 。BBS 论坛 通常 按 不 同 的 主题 划分 为 很 多 个 版 块 ， 按 照 版 块 或 者 栏 
目的 不 同 ， 可 以 由 管理 员 设 立 不 同 的 版 主 ， 版 主 可 以 对 目 己 的 栏目 或 版 块 进行 删除 、 修 改 或 
锁定 等 操作 。 








MATIE E 


HFA NAR: 


掌握 BBS 论坛 系统 的 功能 页 面 规划 

建立 BBS 论坛 系统 的 数据 库 

BBS 论坛 系统 中 新 增 主 题 、 删 除 主 题 、 回 复 主题 的 方法 
BBS 论坛 系统 后 全 管理 功能 的 开发 
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系统 的 整体 设计 规划 


BBS 主要 功能 是 通过 在 计算 机 上 运行 服务 软件 ， 人 允许 用 户 使 用 终端 程序 ， 通 过 Internet 
来 进行 连接 ， 实 现 用 户 消 有 息 之 间 的 交互 功能 。 系 统 的 开发 比较 复杂 ， 需 要 经 过 前 期 的 系统 规 
划 。 本 章 要 开发 的 BBS 论坛 管理 系统 页 面 的 功能 与 文件 名 称 如 表 8-1 Dra. 


表 8-1 BBS 论坛 系统 网 页 设计 表 




















需要 制作 的 主要 页 面 页 面 名 称 功 能 
BBS 论坛 管理 系统 主页 而 显示 主题 和 回复 情况 的 页 面 
讨论 主题 内 容 页 面 主要 显示 讨论 主题 和 回复 内 容 的 页 面 
浙 增 讨论 主题 页 面 增加 讨论 主题 的 页 面 
回复 讨论 主题 页 面 对 讨论 主题 进行 回复 的 页 面 
后 台 版 主 登 录入 口 页 面 管理 员 登 录入 口 页 面 
后 台 版 主管 理 页 面 对 论坛 进行 管理 主要 页 面 
删除 讨论 页 面 删除 讨论 主题 的 页 面 
删除 回复 页 面 删除 讨论 回复 内 容 的 页 面 
修改 讨论 主题 页 面 upd_title.php 修改 讨论 主题 的 页 面 





下 面 要 制作 的 BBS 论坛 管理 系统 的 网 页 及 网 页 结构 如 图 8-1 所 示 。 
BBS 论坛 管理 系统 
index.php 


访问 者 登录 


m} 
时 
xu 
Jg 
ll 


D 
^ ML 


bbs add. php bbs reply. php admin. php 
del title. php del reply. php upd title. php 


图 8-1 BBS 论坛 管理 系统 结构 图 


content. php admin_login. php 


页 面 整体 设计 规划 


介绍 了 BBS 论坛 省 理 系统 的 整体 设计 规划 ， 在 本 地 站 点 上 建立 站 点 文件 夹 bbs。 将 要 制 


















PHP 


作 的 系统 文件 如 图 8-2 所 示 。 


"CC:\Apache\htdocs\bbs 
AEG) AmE SEV 收藏 IAM 帮助 0) 


QmB- O- B| OBR (odx Cm. 加 文件 来 同步 





地 址 0) 全 C: \Apachethtdocsibbs 


文件 和 文件 夹 芷 务 â - .mmServerScripts 区 notes 区 Connections 


C3 创 娃 一 个 新 文件 来 
Q 将 这 个 文件 来 发 布 到 l KL :anin php 

Web images mdb PHP Script 
Eg HFHNHR 《> 11 KB 


| php admin_login. php | PHP bbs_add. php | Php e da _reply. php 


Qu Ru" x 


E Be php PHP PES reply. php PHP i le php 
ocCr1i cri oCcript 
《> RE (5 su 


11 KB 


E Sar php a- upd ti tle. php 
HP Script HP Script 
<I> 9 KB ar <l> 6 KBO "m 


/g 我 的 电脑 





14 个 对 象 


8-2 ”站 后 规划 文件 
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BBS 论坛 管理 系统 的 界面 要 求 简洁 明了 ， 尽 量 不 要 使 用 过 多 的 动画 和 大 图 片 ， 这 样 可 以 提 





局 BBS 论坛 的 访问 速度 。 要 制作 的 首页 面 和 详细 内 容 页 面 效 末 如 图 8-3 和 图 8-4 所 示 。 


ax) 
LA 


A 论坛 之 家 - Nicrosoft Internet Explorer 
THF AmE SENO KEA IA) 和 帮助 0) 


QAE- O- [ài sk z O -52« 


Hir (0) 8] http: 7/127. 0. 0. 1/bbs/index. php? uL yra Hë Qseg: g 
E 2 ' 








i “PHP 论坛 管理 系统 


侈 发 表 话题 | 2€ Ho 
(» 3» | mk | awe | me| xa — 
BEC LL EEFRBB- 
Jc NN EN RN RN NN 











Copyright & 2011 www.hbculture.com Inc. åll rights reserved. 论坛 之 家 


(AMD Internet 





图 8-3 首页 的 美工 效果 








BBSitin E Ie 


TFT 编辑 下) SEV KEA IR() 帮助 0 
OAE- O- AAO RRO O-5 0 € 


HHE M) 4] http: //127. 0. 0. 1/bbs/ content. php?bbs, id-1 


A 论坛 之 家 - Nicroso ft Internet Explorer DAR) 
" 











N 


| ; < RN 
d | | b 


讨论 主题 ，test 


Li 主题 内 容 : test 


发 表 人 : test TS 电子 邮件 © 主页 











回复 内 容 : test 








| V? 2011-6-07 È EZA © 主页 





Copyright @ 2011 www hbculture.com Inc.All rights reserved. 论坛 之 家 








8-4 ”详细 内 容 页 面 效果 


重点 提示 : 初学 者 在 设计 制作 过 程 中 ， 可 以 打开 光盘 中 的 源 代 码 (code 文件 夹 )， 找 到 
本 章 的 images 文件 夹 ， 其 中 有 已 经 编辑 好 的 图 片 。 


Section 


数据 库 设计 与 连接 


制作 BBS 论坛 管理 系统 的 数据 库 需 要 根据 开发 的 系统 大 小 而 年， 下 面 要 设计 用 于 BBS 
讨论 主题 的 信息 表 bbs_main， 用 于 回复 内 容 的 信息 表 bbs_ref， 最 后 还 需要 建立 一 个 管理 员 
进行 管理 的 信息 表 admin. 


sp 数据库 设计 


首先 建立 一 个 名 称 为 bbs 的 数据 库 ， 并 在 里 面 建立 管理 员 管 理 信息 表 admin、 讨 论 主题 
信息 表 bbs_main 和 回复 主题 信息 表 bbs_ref， 这 3 个 数据 表 将 作为 任何 数据 的 查询 、 新 增 、 
修改 与 删除 的 后 问 文 持 。 

制作 的 步骤 如 下 。 

(1) 打开 “EMS MySQL Manager 2007 Lite for MySQL”, YEA MySQL 数据 库 的 管理 面 
板 ， 如 图 8-5 所 示 。 
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(2) 单 击 工具 栏 的 Create Gpr) 按钮 ， 并 在 打开 的 下 拉 荣 单 中 单 击 选择 “Database 
(数据 库 )” 人 命令， 如 网 8-6 所 示 。 


Get ting Started 


Hd Create new database 
E" Manage exito databases) 

Database Tools 
M" Exmcut SQL script 
© Mirage users 

Help and Support 
(à SA Manager 2007 hep system 
CA MEN reference 

3-1! Internet Resources 

fà SO. Manager 2007 home page Pa Support Cone 


G oa manager 2007 oine documeresson É aa Manager 2007 FAQ 





图 8-5 打开 MySQL 数据 库 管 理 界面 K|8-6 单 击 选择 “Database” 命 令 
ir 


(3) 打开 “Create Database Wizard (建立 数据 库 问 导 )” 对 话 框 ， 输 入 数据 库 的 名 称 
“bbs” 然后 再 单 击 Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 ， 如 图 8-7 所 示 。 


Create Database Wizard 
Create Database 
Specify the name for a new database 
Welcome to the Create Database Wizard! 
This wizard allows you to create a new database and register it in the Database 
Explorer. 


This wizard will generate the SQL statement for creating the database and execute it 
on MySQL server. 





Database name bbs 





Register after creating 








图 8-7 输入 数据 库 的 名 称 “bbs” 


(4) 设置 MySQL 数据 库 的 属性 设置 如 表 8-2 所 示 ， 连 接 设 置 如 图 8-8 所 示 。 然 后 再 单 
i Next (下 一 步 ) 按钮 ， 继 续 下 一 步 的 设置 。 


表 8-2 ”数据库 属性 设置 
Host name localhost Port 3300 


User name root 


Password admin 
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Create Database Wizard 


Create Database 


5et connection properies for a new database 


Host name localhost v Part 3308 7 


User name rant 


Manager m | 
— Manager 
| —— forMySQL [| Use tunneling 
lk. Tunneling 
s) SSH tunneling ( HTTF tunneling 


图 8-8 ERKE 


(5) 打开 新 建 数 据 库 的 SQL 语句 提示 创建 数据 库 bbs， 直 接 单 击 Next (下 一 步 ) 按 
钮 ， 如 图 8-9 所 示 。 





Create Database Wizard 
Create Database 
Result SOL statement. Click the Finish button ta create a new database. 


Result SoL statement: 
CREATE DATABASE bbs’: 





8-9 ”完成 设置 


(6) 单 击 Finish( 完 成) 按钮 ， 打 开 注 册 数 据 库 的 设置 画面 ， 选 择 utf8 字符 集 和 简体 中 


文 版 的 GB2312 版 ， 其 他 的 保持 默认 值 ， 如 图 8-10 所 示 。 












PHP 


Database Registration Info 


Eil Options 
Display Options Host name Port 
[© Directories User name 

fV Logs 
EÈ SSH Tunneling Pagsword 

1i HTTP Tunneling Database name 
Data Options 























Database alias bbs on localhost 








Client charset (utta 








Font charset E: 2 CHARSET (Simplified Chinese characters: Iz 




















8-10 选择 简体 中 文 


CI) 单 击 OK 确认) 按钮 ， 束 完成 了 数据 库 bbs 的 新 增 工 作 。 

数据 库 建立 后 ， 还 要 建立 网 页 数据 所 需 的 数据 表 。 这 个 网 站 数据 库 的 数据 表 分 别 是 BBS 
讨论 主题 的 信息 表 bbs_main、 用 于 回复 内 容 的 信息 表 bbs_ref、 管 理 员 进行 管理 的 信息 表 
admin。 建 立 数据 库 后 ， 接 着 再 按 左边 的 “Connect to Database GEROER” Kir AKH 
连接 上 。 这 3 张 数 据 表 的 字段 结构 内 容 说 明 如 下 。 

(1) 建立 数据 库 bbs 后 ， 用 鼠标 右键 单 击 选择 Table 表格， 选项， 在 打开 的 采 单 中 单 
击 选择 “New Tabe GIRO” MẸ, WK 8-11 Dr 








SQL M 2007 for 下 7S0L bbs ón localhost [bbs] fæ VO fx 


LI: 
Tw 3*5 Fr 23242:5S*5À5 9552229552 


i $ 1 Ai Xi d aS Mu Ww [- 
iljieewe -| 3 E n Getting Started 





[he Create new database [ft Create rew table 


[iip Manage existing databases) l^ Create new database cbject 


E Execute SQL script [" 4 Execute query 


$a Manage permissions 


(à SA Manager 2007 help system 


te Cureeed To (à) Ma reference 
i — . hternet Resources 
ocunost eon on Iocanost rabies 0 
[Titas p S Manager 2007 home page 他- Support Contor 


@ sd Manager 2007 on-line documentation Q SOL Manager 2007 FAQ 


8-11. 开始 建 数 据 表 


(2) 数据 库 右 方 夯 面 会 出 现 新 建 数据 表 Tabe 的 设置 区 域 , 含有 “Table (表格 )”、 
“Fields (内 容 )”、“DDL (驱动 )”3 个 选项 卡 ， 先 在 “Table (表格 )” 中 输入 数据 表 名 
bbs main, AE 8-12 所 示 。 
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BBS 论坛 管理 系统 


EE a 





m 


| | Chancer Sabi | Fia Options | Merge Tabla Ciconia | Feclersted Table Opliong |- 


























图 8-12 输入 数据 表 名 bbs main 
(3) 然后 再 切换 到 “Fields (内 容 )” 选 项 卡 中 ， 输 入 数据 域名 以 及 设置 数据 域 位 的 相关 
数据 ， 如 图 8-13 所 示 。 对 讨论 主题 做 一 个 全 面 的 分 析 ， 设 计 bbs main 的 字段 结构 如 表 8-3 
所 示 。 





表 8-3 讨论 主题 信息 表 bbs_main 





发 布 主 题 的 时 间 VARCHAR 20 
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8-13 bbs main 数据 表 





"s PHP+ 


(4) 回复 主题 信息 表 bbs ref 字段 结构 采用 如 表 8-4 所 示 的 结构 。 设 计 后 的 数据 表 如 图 


8-14 HIZR o 


E A 
主题 编写 
回复 主题 编号 
回复 主题 人 的 姓名 
回复 主题 时 间 
回复 主题 内 容 
回复 人 性 别 
回复 人 的 个 人 主页 
回复 人 的 e-mail 


Databases 
- EJ Ilesalhoet 


3] memher on inen 
j| news on lc ast 
引 dou on locare 
| pharti cr kanker 
j|] voe on iacnihost 
T bba on localhost 


[El eee 





R 8-4 回复 主题 信息 表 bbs ref 


ESOL Eanager 2007 for Ny5glL bby on localhoxt. [bbs] [Table [bbs ref] [bbs 


Fidd Hren Fielel Type 
| E] bia moin, Er INTEGER 
LL bis Je P bea, ret Im INTFCER 

Generi . HI] bia mu name VARCHAR 

| E] bea, ret dime VARCHAR 

| D [e] Riresh EI] bien. ret, ennrtent TEXT 
SF compie A] pea, ret, me VARCHAR 
* Bia Grants on labis EH bea. rest uni VARCHAR 


E) bbs on kecali [es 


Fi bha rei nmad VARCHAR H 


gorainast bas an nealhagtTahlenduha ref i 


EFCHEF 
ARF be ZU 


| re 
aR HAR |l = m ries on 


I] bbs, ssi D [HT 


图 8-14 bbs ref 数据 表 





(5) 最 后 设计 用 后 台 


登录 管理 的 admin 数据 表 ， 字 段 结构 采用 如 表 8-5 所 示 的 结构 。 设 





计 后 的 数据 表 如 图 8-15 MZR. 


BOX 
管理 员 信息 编号 
管理 员 账 号 


管理 员 密 码 








DA EX PEG EE 
便 后 面 登录 碍 询 使 用 。 








表 8-5 管理 员 管 理 信息 表 admin 


WP. Ea EHAK admin 里 输入 用 户 名 和 蜜 但 都 为 admin， 以 方 





tame 
11 
11 
A 
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A 
A 
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ipea" mec B 
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BBS 论坛 管理 系统 


iba on lornihost [hbs] [Table = [ndmiml [bbs om 
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8-15 后 台 管 理 admin 数据 表 


了 定义 bbs 站 点 


在 Dreamweaver CS 5.5 中 创建 一 个 “论坛 管理 系统 ”网 站 站 点 bbs， 由 于 这 是 PHP 数据 
库 网 站 ， 因 此 必须 设置 本 机 数据 库 和 测试 服务 器 ， 主 要 的 设置 如 表 8-6 所 示 。 





站 点 名 称 bbs 
本 机 根 目录 CAApacheWtdocsWbbs 
测试 服务 器 CAApacheMtdocsV 
网 站 测试 地 址 http://localhost/bbs/ 
MySQL 服务 器 地 址 C:\Documents and Settings\All UsersVApplication DataMySQLMMySQL Server 5.5\data\bbs 
管理 账号 / 密码 root / admin 
数据 库 名 称 bbs 


创建 bbs 站 点 具体 操作 步骤 如 下 。 
(1) 首先 在 CAApacheWtdocs 路 径 下 建立 bbs 文件 夹 ， 如 图 8-16 所 示 ， 本 章 所 有 建立 的 
网 页 文件 都 将 放 在 该 文件 夹 下 。 
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p) REETTERMX ERA 2011-1-8 0:00 
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D SSXRE anum XER füii-1-3 18 3 
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(2) 运行 Dreamweaver CS $.3， 选 择 菜 单 栏 中 的 “站 
上 护 ” 一 “管理 站 点 ”命令 ， 打 开 “ 管 理 站 点 ”对 话 框 ， 如 
图 8-17 所 示 。 

(3) 对 话 框 的 左边 是 站 点 列表 框 ， 其 中 显示 了 所 有 已 
经 定义 的 站 点 。 单 击 右边 的 “新 建 ” 按 钮 ， 打 开 “ 站 点 设 
置 对 象 ” 对 话 框 ， 进 行 如 下 参数 设置 。 

“站 点 名 称 ”:， bbs. 

“本 地 站 点 文件 来” C:\Apache\htdocs\bbs\。 

如 图 8-18 所 示 。 


站 点 设置 对 和 象 bbs 























图 8-17 “管理 站 点 ”对 话 框 


Dreamweaver 站 点 是 网 站 中 使 用 的 所 有 文件 和 资源 的 集合 。 Dreamweayver 
站 点 通常 包含 两 个 部 分 ; 可 在 其 中 存储 和 处 理 文件 的 计算 机 上 的 本 地 文件 
来， 以 及 可 在 其 中 将 相同 文件 发 布 到 web 上 的 服务 器 上 的 远程 文件 夹 。 





您 可 以 在 此 处 为 Dreamweaver 站 点 选择 本 地 文件 来 和 名 称 。 
站 点 名 称 ， 
本 地 站 点 次 件 夹 ; | Capache\htdocs\bbs' e 





K|8-18 Æ bbs 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 菠 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 8-19 所 示 的 参数 设置 。 

“IRI REER”: bbs. 

“连接 方法 ” 本地/ 网络。 

服务 器 文件 夹 ": C:\Apache\htdocs\。 

“Web URL”: http:// localhost/ bbs/。 


站 点 设置 对 和 象 bbs 








Ragam [bs | 
REDIR: 
IRS SRIF: | CA pachelhtdocs lg 




















图 8-19 设置 “基本 ”选项 卡 














管理 系统 





(5) 设置 后 再 单 击 “高 级 ”选项 不， 打开 “高 级 ”服务 器 设置 对 话 框 。 单 击 “ 维 护 同步 
信息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 选择 PHP MySQL 来 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 8-20 所 示 。 


站 点 设置 对 得 bbs 








版 本 控制 
> 高 级 设置 





维护 同步 信息 
O 保存 时 自动 将 净 件 上 传 到 服务 器 
O 自用 文件 取出 功能 

[VI 打开 文件 之 前 取出 


职 出 名 称 ; 
电子 邮件 地 址 ; 


测试 服务 器 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 
服务 器 模型 :| PHP MySQL E 























8-0 设置 “高 级 ”选项 卡 


(6) 单 击 “ 人 保存” 按钮， 返回“ 服务 器 ”设置 对 话 框 ， 再 单 击 选 择 “ 测 试 ” 复 选 按钮 ， 
如 图 8-21 所 示 。 
站 点 设置 对 犁 bbs 


您 将 在 此 位 置 选择 举 载 web 上 的 页 面 的 服务 器 。 此 对 话 框 的 设置 来 自 
Internet 服务 提供 商 (ISP) 或 web 管理 员 。 








注意 ; 要 开始 在 Dreamweaver 站 点 上 工作 ， 您 无 需 完成 此 步骤 。 如 果 要 连接 到 Web 并 发 
布 页 面 ， 您 只 需 定 以 一 个 远程 服务 器 即 可 。 


| 远程 “测试 | 





8-21 设置 “服务 器 ”参数 
单 击 “ 保 存 ” 按 钮 ， 则 完成 站 点 的 定义 设置 。 在 Dreamweaver CS 5.5 中 就 已 经 拥有 了 刚 


才 所 设置 的 站 点 bbs。 单 击 “ 完 成 ”按钮 ， 关 闭 “ 管 理 站 点 ”对 话 框 ， 这 样 束 完成 了 
Dreamweaver CS 5.5 测试 论坛 管理 系统 网 页 的 网 站 环境 设置 。 


SL 设置 数据 库 连 接 











完成 了 站 点 的 定义 后 ， 接 下 来 就 是 BBS 论坛 管理 系统 网 站 与 数据 库 之 间 的 连接 。 网 站 












PHP 


与 数据 库 的 连接 设置 如 下 。 


(1) 将 光盘 中 设计 的 本 章 文件 复制 到 站 点 文件 夹 下 ， 打 开 BBS 论坛 首页 index.php, 
如 图 8-22 所 示 。 
DW | 器 "| 四 ”| O cue (Spe) | 


文件 (7) 编辑 (E) 查看 (WV) 插入 (I) EAM 格式 (0) 命令 ([C) 站 点 (5) 窗口 ( 吉 ARH) 


(3 











ü GÈ C n it: EHES /fC |; SMS htdocs/bbs/index. php EEGUNELRAMASE: 
hs j 1. 请 为 该 净 件 创建 一 个 站 点 。 
A v 2. 选择 一 种 立 档 类 型 。 
3. 设置 站 点 的 测试 服务 器 。 
4. ENS G) 按钮 并 选择 记 





”PHP 论坛 管理 系统 ;下 


10096 (338) = 























目前 没有 发 表 任 何 主题 


Copyright @ 2011 www. hbculture. com Inc. All rights reserved. 论坛 之 家 


5 admin login. php 
PD bbs add. php 
€ = 一 一 一 一 = - -一 = T bbs reply.php 
body? (table? tr? <td> <table> Ctr? (td? [Ct able?) (RI Q 100$ 896 x 431v 1 K / 1 fh Unicode (UTF-8) LB content. php 
$ — : -o del reply.php 
zx 80! whoo |s ~| BAT) HFFA) Sh T) del title php 
can 3C) [i 间距 人 G) 0 | 边框 (8) CT index.php 


^5) upd title.php 
3 ovg gs & C | | 
Ta (3 日 期 : 2011-8-5 12:07 









































8-22 ”打开 论坛 首页 


(20 单 击 选择 菜单 栏 上 的 “窗口 ”一 “数据 库 ” 人 命令， 打开“ 数据库” 面板 。 在 “ 数 
据 库 ”面板 ， 单 击 选择 “+” 按 钮 ， 并 在 EE bale ^MySQL 连接 ”命令 ， 如 图 8-23 
所 示 。 





TIE 用 动 寿 数 据 : 
1 ATUS TFI Hh Ee 

2, 选择 一 种 立 档 闫 型 。 

3. NEED GB iie. 

4. Sii Em + HURE. 


图 8-23 选择 “MySQL 连接 ”命令 


(3) 在 弹出 的 “MySQL 连接 ”对 话 杠 中， 输入 “连接 名 称 ” 为 bbs,“MySQL 服务 器 ” 
名 为 localhost, “HPZ” X root， 密 人 码 为 admin。 选 择 所 要 建立 连接 的 数据 库 名 称 ， 可 以 单 
击 “ 选 取 ” 按 钮 ， 浏览 MySQL 服务 器 上 的 所 有 数据 库 ， 如 图 8-24a 所 示 。 选 择 刚 建立 的 范 
例 数 据 库 bbs， 具 体 的 设置 内 容 如 图 8-24b 所 示 。 
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连接 名 称 : 
MySQL 服务 器 : 
用 户 名 : 

密码 : 

数据 库 : 





bbs 








localhost 








root 








WEEEK 











bbs 











book 
db_shop 
gbook 


00 
information schema 


news 
performance schemaold 
phpweb 

















8-4 设置 MySQL 连接 参数 
(4) 单 击 “ 测 试 ” 按 钮 ， 测 试 与 MySQL 数据 库 的 连接 是 否 正 确 ， 如 果 正 确 ， 则 会 出 一 
个 消息 框 ， 如 图 8-25 所 示 ， 这 表示 数据 库 连接 设置 成 功 。 
单 击 “确定 ”按钮 ， 则 返回 编辑 页 面 ， 在 “数据 库 ” 和 面板 中 则 显示 绑 定 过 来 的 数据 库 ， 
如 图 8-26 所 示 。 


数据 库 | 绑 定 | 服务 器 行为 | 二 


*so— TEW. PE [e] 





下 7Y5QL 连接 





(g bbs 

日 “七 ”脚本 编制 
E BB admin 

-= 0B9 ID Gnt 11 必需 的 ) 

j j MÀ Ta password (varchar 20 必需 的 

| | Rh username (varchar 20 必需 的 

I m-Bg bbs main 

: m-Bg bbs ref 

s WB 

mae Tace 


连接 名 称 : 
MySQL 服 等 器: 
用 户 名 : à) 成 功 包 了 连接 脚本 。 

TH: 

数据 库 : 


Dreamweaver 






确定 





< lll | > 


8-26” 绑 定 的 数据 库 





图 8-25 设置 成 功 





BBS 论坛 常理 系统 主页 面 设计 








在 Dreamweaver 中 定义 站 点 ， 建 立 数据 库 连 接 后 ， 就 可 以 进入 PHP 网 页 页 面 的 设计 阶 
段 。 首 先 制作 最 重要 的 首页 index.php. index.php 页 面 主要 显示 所 有 的 讨论 主题 和 最 新 回复 


的 一 些 信息 。 


UL BBS 论坛 管理 系统 主页 面 


BBS 论坛 管理 系统 的 主页 面 index.php 显示 所 有 的 讨论 主题 、 每 个 主题 的 点 击 数 、 回 复 
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AANEEN, 访问 者 可 以 单 击 要 阅读 的 标题 链接 至 详细 内 容 ， 管 理 员 单 击 “ 管 
图 标 进 入 管理 页 面 。 系 统 主页 面 mdex.php 的 静态 页 面 设计 如 图 8-27 所 示 。 


A wiy - Nicroso ft Internet Explorer B) 
" 


Tr aE 查看 (WV) Rwa 工具 (TI) $Bh00 

QAE- OQ-.i[9imtf» mk xiex O6 2-354 

地 址 部 ) Æ] http: //127.0. 0. 1/bbs/ Bi Ra pea 链接 Q Sna E 
- S 











: PHP 论 坛 管理 系统 元 
] 


BU. Qo ee e RR s : | 
查询 主题 : "olli. s 多 发 表 话题 | em 
作者 | BE | SR | HR xewa 


目前 没有 可 主题 
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8-27 BBS 论坛 管理 系统 主页 面 静态 设计 效果 


许 细 的 操作 步骤 如 下 。 

G) 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 由 按钮 ， 在 弹出 的 菜单 中 选择 “ 记 
录 集 (查询 )” 命 令 ， 在 弹出 的 对 话 框 中 进行 如 下 设置 。 

1) 在 “名 称 ” 文 本 框 中 输入 rs bbs 作为 该 记录 集 的 名 称 。 

2) 从 “连接 ”下 拉 列 表 框 中 ， 选 择 数 据 源 连接 对 和 象 bbs- 

3) 从 “表格 ”下 拉 列 表 框 中 ， 选 择 使 用 的 数据 库 表 对 和 象 为 bbs_main。 

4) 在 “ 列 ” 栏 中 选择 “全 部 ” 单 选 按钮 。 

完成 的 设置 情况 如 图 8-28 所 示 。 


Eee 





8-28 ”设置 “记录 和 集 ” 对 话 框 








第 8 草 GIJXSUESES 











(2) 再 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 
的 SQL 语法 ， 如 图 8-29 Wr. 


01. SELECT 
02. "bbs Main.bbs ID, 
03. bbs Main.bbs Time, bbs Main.bbs Hits 
04. ^bbs Main.bbs Title, bbs Main.bbs url, 
bbs Main.bbs email, bbs Main.bbs sex, 
bbs Main.bbs Face, bbs Main.bbs Content, 
05. bbs Main.bbs Name,COUNT(bbs Ref.bbs Main ID) AS ReturnNum, 
06. MAX(bbs Ref.bbs ref Time) AS LatesTime 
07. FROM 
08. bbs Main LEFT OUTER JOIN bbs Ref ON 
09. bbs Main.bbs ID-bbs Ref.bbs Main ID 
10. GROUP BY bbs Main.bbs ID 





. s | 


: SELECT bbs Main. bbs ID, bbs Main.bbs Time, bbs Main. bbs Hits, 
bbs Main. bbs Title, bbs Main. bbs url, 
bbs Main. bbs email, bbs Main. bbs sex, 
bbs Main. bbs Face, bbs Main. bbs Content, bbs Main. bbs Name, COUNT 
(bbs Ref.bbs Main ID) AS ReturnHum, MAX(bbs Ref.bbs ref Time) AS 


























表格 添加 到 SQL: 


m WE 
d. ”预存 过 程 














WHERE 


ORDER BY 





图 8-29 改写 SQL 语句 


程序 说 明 : 

第 一 条 bbs ref 数据 表 中 的 记录 可 以 通过 bbs main ID 字段 关联 到 bbs main. 数据 表 中 的 
bbs ID 字段 。 因 为 bbs ref 数据 表 中 对 应 的 数据 可 能 不 存在 ，bbs_main 数据 表 并 非 一 定 有 对 应 回 
复 的 话题 。 所 以 LEFT JOIN 将 接合 关系 中 的 两 个 数据 表 分 成 左右 两 个 数据 表 ， 其 中 左边 数据 表 
在 经 过 接合 后 ， 不 管 右边 数据 表 是 否 存 在 ， 仍 然 会 将 资料 全 部 列 出 。 简 单 的 说 ， 怠 是 不 管 讨 论 
主题 bbs main 是 否 有 任何 的 回复 bbs ref, fEH] LEFT JOIN 可 以 将 数据 表 bbs. main 中 的 所 有 讨 
论 主 题 都 显示 出 来 。 

另外 ，GROUP BY 语句 是 针对 bbs main 数据 表 中 的 bbs ID 字段 ， 第 2 一 6 行 的 意思 是 
取出 bbs_main 数据 表 中 的 特定 字段 内 容 。 同 时 将 bbs_ref 中 的 关联 字段 取出 ， 获 得 bbs_time 







































PHP 


和 bbs ID 的 两 个 字段 内 容 。bbs_ref time 字段 取 所 有 记录 当中 时 间 最 新 回复 的 那 一 条 用 来 显 
示 。 而 bbs_ID 字段 则 用 COUNT 计算 有 多 少 人 回复 的 数目 。 

(3) 绑 定 记录 集 后 ， 将 记录 集 的 字段 插入 至 index.php 网 页 中 的 适当 位 置 ， 如 图 8-30 
所 示 。 





Dw | eH -|[98 — Oc [S] ES 
Tr ”编辑 (FE) 查看 (Y) 插入 (I) EM) EAO 命令 (C) 站 点 (3) 窗口 人 ARH 
[EY ET php 


bbs. php 
fi KR p [4  XHNB BE M.Qu ERE .D. 005 
j GD C qiii: £ile:///C|/Apache/htdocs/bbs/index. php 
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目前 没有 用 表 寿 何 主题 


Copyright @ 2011 www. hbculture. com Inc. All rights reserved. WEZ F 
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文件 活动 已 完成 。 























8-30 ”字段 插入 全 index.php 


(4) 插入 字段 后 ， EM UC TRANI AI 





像素 ， 如 图 8-31 所 示 。 “确定 ”按钮 ， E ARUM. 

C5) 插入 “图 像 占 位 符 ” 之 后 ， 选 中 “网 像 占 位 符 ”， 单 击 “ 属 性 ”面板 中 的 “ 源 文 
件 ” 文 本 框 后 面 的 “浏览 文件 ”按钮 呈 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 
“数据 源 ” 单 选 按钮 ， 然 后 在 “ 域 ” 列 表 杠 中， 选择 “记录 集 (rs_bbs)” 选 项 中 的 bbs Face 
字段 ， 如 图 8-32 所 示 。 


选择 文件 名 自 : 〇 ) 文件 系统 站 点 根 目录 
(5 数据 源 站 点 和 服务 器 





域 : B 记录 集 rs bbs) 





8B | 
as 


bbs Content 
bb oe e 
PP) 





E 


| 
格式 : 无 
| 


URL: <?php echo $row rs bbs[ bbs_Face’ ]; ?> 



































在 站 点 定义 中 更 改 默 认 的 链接 相对 于 
| 确定 || mud 





8-31 设置 “图 像 占 位 符 ” 对 话 框 8-32 ”选择 字段 
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(6) 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 绑 定 。 接 下 来 进行 显示 区 域 的 设置 ， 首 先 ， 选 取 
记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-33 所 示 。 





图 8-33 ”选择 要 显示 的 数据 表格 


C) 单 击 “服务 器 行为 ”面板 上 的 邮 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 显 示 区 域 ” 一 “如 
果 记 录 集 不 为 至 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 
选择 “记录 和 集 ”下 拉 列 表 框 中 的 “rs_bbs” 选 项 ， 如 图 8-34a 所 示 。 单 击 “ 确 定 ”按钮 回 到 
编辑 页 面 ， 会 发 现 先前 所 选取 要 显示 的 区 域 左 上 角 出 现 了 “如 果 有 下 列 情况 ， 即 显示 ”的 灰 
色 卷 标 ， 这 表示 已 经 完成 设置 ， 如 图 8-34b Hrs. 











MA IK SEA 29 TIER 








Dw | 设 i 器 ”| OG cue [ep] mE 
THT 编辑 (FEF) 查看 (Y) 插入 (I) 修改 (OD 格式 (0) 命令 (5C) 站 点 (5) ”窗口 (由 帮助 0D 

indez. php* X 
Ut bbs. php 














记录 集 Cs_bbs) 

如 果 记 录 集 趟 为 室 则 显示 (rs bbs) 
动态 尾 性 (img. sre, $row_rs_bbs[... 
动态 属性 (a href, $row rs bbs['... 
动态 次 本 (rs bbs bbs Title) 
mh (rs bbs. bbs Hame) 
ERAS (rs bbs ReturnNum) 
ERU (rs bbs LatesTime) 
动态 女 本 (rs bbs bbs Hits) 

动态 文本 (rs bbs. bbs Time) 





CE 


? ult a 
| "s. 
| {rs_bbs. bbs_Title} 














ale 可 ai 可 
783 x 401v T1 K / 2 秒 Unicode (UTF-8) - EI | Lya B | F] 
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BED E-G Coton 
a- images 
B css ma) E a EEL) | | E iv] B so. | 
mmt... 列表 项 目 7 admin. php 11KB lv 
u J| > 


@ BM: 2011-6-5 12:07 (HÆ 




















图 8-34 ”完成 显示 设置 
(8) 选择 没有 发 布 主题 数据 时 要 显示 的 文字 “目前 没有 发 表 任 何 主题 ” 根据 前 面 的 操 
作 方 法 ， 将 区 域 设 定 成 “如 果 记 录 集 为 衬 则 显示 区 域 ” 如 图 8-35a. b Br. 
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K|8-35 ”选择 没有 数据 时 的 显示 


C9) 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设置 ， 单 击 index.php 页 面 中 要 重复 的 记录 
列 ， 如 图 8-36 所 示 。 





irs bbs.bbs Title] 





EY 
RN e ELS ED Sm... 





图 8-36 ”选择 要 重复 显示 的 记录 列 


(100 单 击 “应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 列 
表 中 ， 选 择 “ 重 复 区 域 ” 命 令 ， 在 打开 的 “重复 区 域 ” 对 话 杠 中， 设置 显示 的 记录 数 为 20， 
如 图 8-37 所 示 。 


(wx 
. © 20 | 记录 
O 所 有 记录 


帮助 








图 8-37 ”选择 一 次 可 以 显示 的 记录 数 


(11) 单 击 “ 人 确定” 按钮 ， 回 到 编辑 页 面 ， 会 及 现 先前 所 选取 要 重复 的 区 域 左 上 角 出 现 
了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 
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(12) 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 面 ， 当 记录 集 
超过 一 页 ， 束 必须 要 有 [上 一 页 ]、[ 下 一 页 ] 等 按钮 或 文 
学 ， 让 访问 者 可 以 实现 翻 页 的 功能 ， 这 就 是 “记录 集 导 
航 条 ”的 功能 。“ 记录 集 叶 航 条 ”按钮 位 于 “插入 ” 工 
具 栏 的 “数据 ”中 ， 因 此 将 “插入 ”工具 栏 由 “常用 ” 
切换 成 “数据 ”类 型 ， 单 击 “ 记 录 集 导航 条 ”|[ 加 工具 按 
钮 ， 如 图 8-38 所 示 。 

(13) 在 打开 的 “记录 集 导 航 条 ”对 话 框 中 ， 选 取 
要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 “文本 ”， 如 
图 8-39a 所 示 ， 然 后 单 击 “确定 ”按钮 回 到 编辑 页 面 ， 
会 及 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 8-39b 所 示 。 
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8-39 


dri tbs. bha Wasal [e abha Haturua] [ri pbs. Latestimal ies, Hs Pba Hits] [ri bha. bha Tisal 





添加 “记录 集 导 航 条 ” 





数据 v 
(A Spy 重复 项 
EL spy 重复 列表 
(Q ERR 

f RU 

f) mss 
dj- Ems 
diosRRSKA 
ii. 显示 记录 计数 
C EHEAR 
597 插入 记录 v 











8-38 选择 “记录 集 导航 条 ” 


Dw | m | E Qaw | 
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(14) 在 “讨论 主题 ”上 加 入 “ 转 到 详细 页 面 ”的 设置 ， 用 来 显示 特定 主题 的 详细 内 容 





及 相关 的 回复 。 选 取 编 辑 页 面 中 的 rs_bbs.bbs_Title ^^ Ec, 
如 图 8-40 所 示 。 

(150 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 
击 “ 浏 览 文件 ”图 标 ， 在 弹出 的 “选择 文件 ”对 话 框 中 选 
择 用 来 显示 详细 记录 信息 的 页 面 contentphp， 设 置 如 图 


ADRESSES HERI 





8-40 ”选择 字段 









PHP-* 





8-41 Brzn. 


选择 文件 名 自 : GO 文件 系统 METI EES 


O 数据 源 站 点 和 服务 器 
查找 范围 0): C bbs | O 2 ega 


ce  mmserverScripts bcd admin login. ph "9 del title.php 
Ce notes "7$ bbs add. php 中; index.php 
([CjConnecti ons e] bbs_reply. php ‘upd title.php 
Dineees - FE 

mdb "5 del ref. php 

"9 admin. php Rc del reply.php 

















Abt): content. php 
TH (T): | 所 有 文件 o) 














VRL: content. php 
相对 于 : | $5 v | index. php 
在 站 点 定 尺 中 更 改 默 认 的 链接 相对 于 














图 8-41 选择 链接 文件 


(16) 童 击 “参数 ” 投 钮 ， 议 置 超级 链接 要 附 市 的 URL 参数 的 名 称 与 值 ， 如 几 8-42a 所 
示 。 将 参数 名 称 命名 为 bbs id. (EU ELBITIES] pe Padi ART 8-42b 中 车 标 所 指 回 的 图 标 。 


[ug ERR es bts) 


bbz Time 
bbs Hits 
bbs Title 
bbs url 
bbs semail 
: bbs sex 
j bbs Face 
: bbs Content 


: 45 bbs Hame 
T.-— 


"php echo $row rs bbs[... | z 


tex 
ERU T 











图 8-42 “参数 ”和 “动态 数据 ”对 话 框 


(17) 单 击 “ 确 定 ” 按 钮 完成 “ 转 到 详细 页 面 ”的 设置 ， 在 index.php 页 面 中 有 两 个 链接 
图 示 “ 管 理 ” 与 “发 表 话 题 "”， 必 须 设 定 其 链接 网 页 ， 如 表 8-7 所 示 。 


表 8-7 按钮 链接 的 页 面 表 


按钮 名 称 链接 页 面 
管理 admin_login.php 


发 表 话 题 bbs_add.php 
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BBS 论 坛 管理 系统 


:搜索 主题 功能 制作 





在 index.php 这 个 页 面 上 加 入 搜索 的 功能 ， 访 页面 上 的 功能 设计 如 图 8-43 所 示 。 


:| ü A 


8-43 ”搜索 主题 设计 








制作 步骤 如 下 。 
(1) 将 查询 主题 的 文本 域 命名 为 keyword。 设 置 如 图 8-44 Pr. 
属性 
立 本 域 ERPREE 0) 类 型 mE) Omm OTEP) S stylei8 
RévHEOS | WED | 多 
OZA m 
O RE t) 


8-44 ”设置 keyword 文本 域名 





(2) 将 之 前 建立 的 记录 集 rs bbs 做 一 些 更 改 ， 打 开 记 录 集 ， 并 进入 “高 级 ”i 
在 原 有 的 SQL 语句 中 GROUP BY bbs_Main.bbs_ID 前 面 ， 加 入 一 段 查询 功能 的 语法 : 


where bbs, Title like '%".$keyword." %' 


SQL 语句 将 变 成 如 图 8-45 所 示 。 














M 








LatesTim 
FROM bbs re in LEFT OUTER JOIN bbs_Ref ON 
bes Mai iy .bbs ID-bbs Re £. bbs Main ID 

ra bbs THAI a -———raEru 


bs Title like 六 .$key i j 
GEDUE 5 bbs Main. bbs ID 














数据 库 项 : 表格 添加 到 SQL: 
= 
d. Next 


WHERE 


ORDER BY 








8-45 修改 SQL 语句 








(3) 再 切换 到 代码 设计 窗口 。 在 rs_bbs 记录 和 集 绑 定 的 代码 中 加 入 代码 : 


$keyword-$ POST[keyword]; /定义 keyword 为 表单 中 "keyword" 的 请 求 变量 


设 定 对 话 框 。 


e 












PHP 





如 图 6-46 所 示 ， 完成 设置 。 
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8-46 ”加 入 代码 





(4) 以 上 的 设置 完成 后 ， 系 统 主页 面 index.php 就 有 查询 功能 了 ， 可 以 按 下 (F12) 键 至 
S 测试 一 下 是 耕 能 正确 地 查询 并 显示 。index.php 页 面 会 显示 所 有 网 站 中 的 讨论 主题 ， 
wee 8-47 所 示 。 





us 访问 者 页 面 的 设计 








F 论坛 之 家 一 了 icrosoft Internet Explorer 

THFT AHE 查看 WV) REA 工具 (IT) 帮助 0) 

QmB-O-|9i(dt Psk kiez 6 2-54 

地 址 0) |] http: //127.0. 0. 1/bbs/?keyword-test&Subni t-XESXOFNASNEGNAFNA2 二 输入 关键 词 搜索 €-Ejses sm Q snust g 


b. nil 

















发 布 时 间 


ERISA R RANER 


Copyright @ 2011 www. hbculture. com Inc. All rights reserved. 论坛 之 家 











图 8-47 主页 面 讨论 主题 的 浏览 效果 
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耸 坛 访 问 者 使 用 的 页 和 面 有 讨论 主题 内 容 页 面 contentphp 和 回复 讨论 页 面 
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EOM T ON ETETETT Ea  QIMAALESENES 


bbs reply.phpe F TLLA T ARX PAA Va AIEE e 
s 讨论 主题 内 容 页 面 


讨论 主题 内 容 页 面 content.php 是 实现 讨论 主题 的 详细 内 容 页 面 。 这 个 页 面 会 显示 讨论 主 
题 的 详细 内 容 与 所 有 回复 者 的 回复 内 容 ， 其 静态 页 面 设计 如 图 8-48 所 示 。 


É 论坛 之 家 一 icCroso ft Internet Explorer DAR) 
THF AmE SA0 收藏 必 ) IAM EH) [7 
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地 址 0) E http: //12T. 0. 0. 1/bbs/content. php 
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G pz © 主页 














D G 电子 邮件 © 主页 
目前 役 有 回复 








Copyright @ 2011 www hbculture.com Inc.All rights reserved. 论坛 之 家 








8-48 讨论 主题 内 容 页 面 设计 效果 


详细 的 操作 步骤 如 下 。 

(1) 在 content.php 这 个 页 面 中 ， 要 同时 显示 讨论 主题 与 回复 主题 的 内 容 ， 因 此 需要 把 两 
个 记录 集 进行 合并 ， 一 次 取得 这 两 个 数据 表 中 的 所 有 字段 ， 根 据 主题 页 面 传送 过 来 的 URL 
参数 bbs ID 进行 筛选 。 

(2) 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 凶 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 
“记录 集 〈 得 询 )” 人 命令， 在 打开 的 “记录 集 ” 对 话 框 中 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 高 级 
设 定 的 对 话 框 ， 将 现 有 的 SQL 语句 改 成 如 下 的 SQL 语句 ， 如 图 8-49 所 示 。 


01. SELECT 

02. bbs main.*,bbs ref.* 

03. FROM 

04. bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID- 
bbs ref.bbs main ID 

05 WHERE bbs main.bbs ID 2'"".Sbbs ID." 
























"PHP 





名 称 : detail 








SQL: SELECT bbs main. *,bbs ref.* 
FROM bbs main LEFT OUTER JOIN bbs ref ON 
bbs main. bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'".$bbs ID." | 








表格 
m x9 视图 
Gd. MPH 


ORDER BY 








8-49 改写 SQL 语句 


重点 说 明 : 同样 用 LEFT OUTER JOIN XJ bbs main 和 bbs ref 中 的 字段 ， 取 得 两 个 数 
据 表 中 的 相关 数据 。 并 且 用 WHERE 3&4], (pit bbs main 数据 表 中 的 bbs ID. 字段 值 等 于 
$bbs ID 变量 值 。 

(3) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 首页 传递 过 来 的 的 参数 ， 因 此 在 议 
页 目 动 生 成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 


$bbs ID-strval($ GET[bbs id']); 











(4) 在 设 定 记 录 集 绑 定 后 ， 先 把 记录 集 detail 中 的 字段 插入 到 页 面 上 ， 再 分 别 插入 两 个 
图 像 占 位 符 ， 两 个 图 像 占 位 符 分 别 绑 定 发 布 人 性 别 形象 bbs sex 字段 和 回复 人 性 别 形象 
bbs ref sex 字段 ， 其 结果 如 图 8-50 所 示 。 


ba phot 


rs php 






! 


b. di 


i dnd a La LAs a adta e L'e a Aaoi da da bda Lu ba Aa Be Measte dd a da bale b adeta u Le e aedade 让 "eren 





m 


AWA 2 [details name] 


ERR : (dete bbe content) 


— — 


S emm Ü 主页 Ogurm 


E URAR: (detallebe nf content) 


FA t (details ral same) 





C7 qdehulhbs mf ne] 26 reap 6 cem 


umo M NU———M———————M—Á— 











| Th om Mi le T2 EJ 2 9€ bids WTA) 


——————— 


8-50 detail 中 的 字段 插入 
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(5) 单 击 选择 主题 表格 中 的 文字 “电子 邮件 ”， 然 后 单 击 “ 属 性 ”面板 中 “链接 ”文本 
框 后 面 的 “浏览 文件 ”按钮 加 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 源 ” 
单 选 按钮 ， 然 后 在 “ 域 ” 列 表 杠 中， 选择 “记录 集 (detail)” 中 的 bbs email 字段 ， 并 且 在 
URL 链接 前 面 加 上 mailto:， 如 图 8-51 所 示 。 


选择 文件 名 自 : OO 文件 系统 


域 : | 日 号 ”记录 集 (detail) 
4 bs ID 

— 42 bbs title 
47 bbs content 
47 bbs name 

— 47 bbs time 

| 47 bbs face 
4 bbs sex 
bbs_email 
37 bbs_url 
4 bbs hits 

i Ea Lim -s2- TI 

格式 : 无 

URL: Imailto: <?php echo $row detail[ bbs email 


在 站 点 定义 中 更 改 默 让 的 链接 相对 于 

















图 8-51 设置 主题 栏 中 的 email 的 链接 


(6) 单 击 选择 主题 表格 中 的 文字 “主页 ”， 单 击 “ 属 性 ”面板 中 “链接 ”文本 框 后 面 的 
“浏览 文件 ”按钮 呈 ， 打 开 “ 选 择 文件 ”对 话 框 ， 在 该 对 话 框 中 选择 “数据 源 ” 单 选 按钮 ， 
然后 在 “ 域 ” 列 表 杠 中， 选择 “记录 集 (detail)” 中 的 bbs_url 字段 ， 并 且 在 URL 链接 前 面 
加 上 http://， 如 图 8-52 所 示 。 


选择 文件 名 自 : 〇 文件 系统 
(5 数据 源 


M[m Gh dE (detail) 
bbs ID 

bbs title 

bbs content 
bbs name 

bbs time 

bbs face 

bbs sex 


bbs email 


y VES WX X WX WWW 


bbs hits 
lil 2.2- 


Tn 





格式 : 天 | vj 
URL: http://K?php echo $row detail['bbs url']| 








在 站 点 定 尺 中 更 改 默 让 的 链接 相对 于 





图 8-52 设置 主题 栏 中 的 url 链接 
CD 利用 第 5. 6 步 中 的 方法 ， 设 置 其 回复 人 的 “电子 邮件 ”和 “主页 ”的 链接 。 一 个 
是 “记录 集 (detail)” 中 的 bbs ref email 字段 ， 一 个 是 “记录 集 (detail)” 中 的 bbs ref url 
字段 ， 如 图 8-53 和 图 8-54 所 示 。 
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选择 文件 名 自 : ORI 
(o 数据 源 


bbs email 

bbs url 

bbs hits 

bbs main ID 
bbs ref ID 
bbs ref name 
bbs ref time 


bbs ref content 


bbs email 

bbs url 

bbs hits 

bbs main ID 
bbs ref ID 
bbs ref name 
bbs ref time 
bbs ref sex bbs ref content 
bbs ref url 


bbs ref email $£ bbs ref url 
Lle 2.£ oomoo 


NYY 
EX S NS NN NN 


bbs ref sex 








格式 : 无 v 格式 : 无 


VRL: mailto: <?php echo $row detail[' bbs ref e| URL: http: //K?php echo $row detail bbs ref u| 


在 站 点 定义 中 更 改 喷 认 的 链接 相对 于 在 站 点 定义 中 更 改 默认 的 链接 相对 于 

















图 8-53 ”设置 回复 栏 中 的 email 的 链接 图 8-54 设置 回复 位 中 的 url 链接 


(8) 单 击 “ 确 定 ” 投 钮 ， 完 成 效 据 源 的 绑 定 设置 ， 在 content.php 页 面 中 有 两 个 链接 图 示 
“管理 ”与 “发 表 话题 ” 必须 设 定 其 链接 网 页 ， 如 表 8-8 HZR o 








表 8-8 按钮 与 链接 页 面 表 


按钮 名 称 链接 页 面 
管理 admin_login.php 
发 表 话 题 bbs_add.php 





(9) 选择 文字 “回复 主题 ” 在 “属性 ”面板 中 找到 建立 链接 的 部 分 ， 并 单 击 “ 浏 览 文 
件 ” 图 标 ， 在 弹出 的 对 话 框 中 选择 用 来 显示 详细 记录 信息 的 页 面 content.php， 设 置 如 图 8-55 
所 示 。 











选择 文件 名 自 ; dre 让 点 根 目录 


查找 范围 0): C) ts «| Od pu 


B  mmServerScripts e] admin_login. php "6, del reply.php 
C notes bcd bbs add.php 全 del title.php 
[Comecti ons 1 s reply.php El index. php 


ID images "6, content.php yupd title.php 


(mdb [E] coten. txt iu 











ac admin. php "6, del ref.php 








XAM: [bbs reply php i 


HSE (T): AAR G+.*) 司 [n 
URL: [bb s_reply. php M 
相对 于 : 文档 v content. php 

在 站 点 定 尺 中 更 改 默 让 的 链接 相对 于 























图 8-55 ”选择 链接 文件 
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C100 蛙 击 “参数 ”按钮 ， 设 置 超 级 链接 要 附带 的 URL 参数 的 名 称 与 值 。 将 参数 名 称 命 
名 为 bbs_ID， 设 置 如 图 8-56a、b 所 示 。 


域 :| 日 GR d (detail) ^ © 


bbs_title ` 
bbs_content C 三 
bbs name 

bbs time 

bbs face 

bbs sex 

bbs email 

bbs url 

bbs hits 

Tle = ocem 


n S S S S ES 


格式 : 无 


HRID: <?php echo $row detail['bbs ID']| 




















图 8-56 “动态 数据 ”对 话 框 


CD 加 入 “服务 器 行为 ”中 “重复 区 域 ” 的 设 定 ， 单 击 contentphp 页 面 中 要 重复 的 表 
格 ， 如 图 8-57 所 示 。 








回复 人 : {detailbbs_ref name] 回复 内 容 : {detailbbs_ref_content} 





EÒ {qetailbbs_ref time) 要 ”电子 邮件 © 主页 





图 8-57 选择 要 重复 的 表格 


(12) 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 上 的 办 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 重 复 区 域 ” 合 令 ， 在 打开 “重复 区 域 ” 对 话 框 中 ， 设 置 显 示 的 记录 数 为 5 条 ， 如 
图 8-58 所 示 。 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 会 发 现 先前 所 选取 要 重复 的 区 域 左 上 和 角 
出 现 了 一 个 “重复 ”的 灰色 标签 ， 这 表示 已 经 完成 设置 。 

















ERE: (detail 
gm. © B | 记录 





O 所 有 记录 








图 8-58 ”选择 一 次 可 以 显示 的 记录 数 


(13) 搬入 “记录 集 导 航 条 ”功能 ， 单 击 到 工具 按钮 ， 在 打开 的 “记录 集 导 航 条 ”对 话 
框 中 ， 选 取 要 导航 条 的 记录 集 以 及 导航 条 的 显示 方式 ， 如 图 8-59a 所 示 ， 然 后 单 击 “ 确 定 ” 
按钮 回 到 编辑 页 面 ， 会 发 现 页 面 出 现 该 记录 集 的 导航 条 ， 如 图 8-59b 所 示 。 














“记录 集 ” 下 拉 列 表 框 中 的 “detail” 选 项 ， 


记录 和 集 导 和 条 











taecheVhtdoczNbbteoathnt php Hx 





讨论 + n. [delia bhs. te 
o ———— 


Fa 
3 EENE : {desuilbbs content) 


[| 
f PRA: (iabe name) 
i 








| F ma ox Darra 


回复 内 容 : feniailbbe_raf contani} 


FRSA, : (dril bka ref nasse] 








hd 
Oed). Ctable? Cte) CU (Cr able] [AQ 10€ — e BAT m 5229 TT K / 2 1€ Vniesds QITF-8) 


b) 
图 8-59 添加 “记录 集 导航 条 ” 


(140 选取 记录 集 有 数据 时 要 显示 的 数据 表格 ， 如 图 8-60 所 示 。 





回复 人 : [detailbbs ref name) 回复 内 容 : {detailbbs_ref_content} 


UP {qetailbbs ref time) $7 EFA © 主页 





图 8-60 选择 要 显示 的 数据 表格 
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(150 单 击 “ 服 务 器 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 菜单 中 选择 “显示 区 域 ” 一 “如 果 


记录 集 不 为 衬 则 显示 区 域 ” 命 令 ， 在 打开 的 “如 果 记 录 集 不 为 空 则 显示 区 域 ” 对 话 框 中 ， 选 择 
如 图 8-61a 所 示 。 单 击 “ 确 定 ” 按 钮 回 到 编辑 页 
面 ， 会 发 现 先 前 所 选取 要 显示 的 区 域 左 上 和 角 出 现 了 一 个 “如 果 符 合 此 条 件 则 显示 …” 的 灰色 卷 








标 ， 这 表示 已 经 完成 设置 ， 如 图 8-61b 所 示 。 





M Io SEP 29 Z7 BA Sio DR 











图 8-61 完成 设置 后 的 效果 


回复 人 : (detaillbbs ref name) 回复 内 容 : (detailbbs ref content] 





UJ (detalbbs rf time) S 电子 邮件 © 主页 





b) 
8-61 ”完成 设置 后 的 效果 〈 续 ) 


(16) 选择 没有 回复 数据 时 要 显示 的 文字 “目前 没有 回复 "， 根 据 前 和 面 的 步 桑 ， 将 下 面 区 
域 设 定 成 “如 果 记 录 集 为 空 则 显示 区 域 "” 如 图 8-62a、b Br. 


I io SE 29 77 M Sio Dx 

















E 


RED 
DARTE S EG TE ILS. F 


2j 


回复 上 : 回复 内 容 : [detailhbs ref content] 
{detal bbs ref name} 


LJ (detalbbs rf time) 电子 邮件 © 主页 
AUS REG ELTE Bs. F 
H Bii Bl 





b) 


K|8-62 ”选择 没有 数据 时 的 显示 


8.42 设 置 点 击 次 数 





在 BBS 论坛 系统 主页 面 中 设置 了 文章 阅读 统计 功能 ， 当 访问 者 点 击 标题 进入 查看 内 容 
时 ， 阅 读 统 计数 目 束 要 增加 一 次 。 其 主要 的 方法 是 更 狐 数 据 表 bbs main 里 的 bbs_hits 字段 来 
实现 。 

详细 操作 步骤 如 下 。 

COD 实现 的 方法 很 徐 单 ， 打 开 contentphp 页 面 ， 在 代码 的 第 50 行 加 入 一 行 更 狐 的 SQL 
语句 : mysql query("UPDATE bbs main SET bbs hits = bbs hits + 1 WHERE bbs ID = 
" $Sbbs ID."'"); 

代 公 说 明 如 下 : 

01.UPDATE bbs_main IE Ýi bbs main 数据 表 
02.SET bbs_hits = bbs_hits + 1 /设置 bbs main 数据 表 中 的 bbs. hits 中 字段 自动 加 1 














"P PHP+ 
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03.WHERE bbs ID = "".$bbs ID." // bbs ID 的 值 等 于 $bbs_ID 变量 中 的 值 


(2) 加 入 的 代码 位 置 如 图 8-63 所 示 。 


= coa etu at does Ws eont ent. paps -0x 








) 
+. 
1 
e y $currentPage = 4 SERVER("M? SELF"); 
v £maxKovs detall = $; 
(pageNun d | ; 
w 1f (1s3et(6 CET['pogeMum detail']))) 4 
o0 (pageNum derail = $ GET[ 'pegelun dezai11']; 
i ! 
[as] i $statthou detail] = $pegeMus detail * £maxRows detallz 
ge i5 Maia select. gp tabase bbs, 6b we M 
[3 4 ydereil = "SELECT tbs pain. *,bbs ref.* FROM bbs mein um OUTER 9m We; ref ON 
spa p — : "bbs zef.bbs báin, "y" VIERE bda main ane. ap Aa „Ebda. "ID. 
ir m Lim ail - mprintf[" LIMIT +d, X4^, $quety il, fè how de i, $maxKous detail); 
g ; tae il = aya " quecy(f query li ty (bbs) ot die rati ma MOM 
E 4 pa etail = mysql fetch AUN deta11); 
£ 
2 
i it ener rias ipd Mortgages proce ( 
= (totalPRows detail = $ GET[*totalRovs detail"): 
) eise ( 
as ¢all_ deras] -— .query(équery de epe 
£. ma * derail = mysql mum ee 11 detail)? 


nere iere Mel sd 





图 8-63 ”代码 加 入 的 位 置 








新 增 讨论 主题 页 面 bbs_add.php 的 功能 是 将 页 面 的 表单 数据 新 增 到 站 点 的 bbs main 数据 
表 中 ， 页 面 设 计 如 图 8-64 Br. 


T C: \Apache\ht docs\bbs\bbs_add. php - [galea 


|:oegdo*os$o9o9o8 
| 
_ 人 主页 


确定 提交 





rt- 
(R| Qj 100€  . T9898 x 591v 81 K / 2 f^ Unicode (UTF-8) — - 


图 8-64 ”新 增 讨 论 主题 页 面 效 来 








详细 操作 步骤 如 下 。 


(1) 在 bbs add.php 页 面 设计 中 ， 表 单 forml 中 文本 域 和 文本 区 域 设置 如 表 8-9 所 示 。 
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这 里 要 注意 性 别 形象 和 心情 的 早 选 控 钮 虱 要 在 属性 面板 中 定义 其 值 。 





表 8-9 RË fomi 中 的 文本 域 和 文本 区 域 设 置 方法 表 


E OX 文本 (区 ) 域 /按钮 名 称 方法 /类 型 e 
性 别 形象 单 选 按钮 

stunt ae 

阅读 次 数 初始 值 为 0 


(2) 在 bbs add.php 编辑 页 面 ， 单 击 “ 服 务 器 行为 ”面板 上 的 外 按钮 ， 在 弹出 的 菜单 
中 ， 选 择 “ 插 入 记录 ”命令 ， 在 “搬入 记录 ”的 对 话 框 设置 如 下 。 

1) 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连 接 对 象 。 

2) 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs main 作为 使 用 的 数据 库 表 对 象 。 

3) 在 “插入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_main， 然 后 再 转 到 
index.php 网 页 。 

4) 在 “ 列 ” 的 列 选 对 话 框 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs main 中 的 字段 一 
一 对 应 起 来 。 

设置 完成 后 该 对 话 框 如 图 8-65 所 示 。 


























提 变 值 ， 自 : forml v| 
连接 : bbs v 
插入 表格 : (bbs_main v 


| bbs content' M, 'FORM.bbs content XERRBÍE' 304 
|' bbs name' M " FORM. bbs name' 获取 值 作为 CN 
, L , LI L LI X* HD = a , [7 z LI 
2 D FE A , , 








到 |: 


|’ bbs_ 
'bbs email' JA “FO 
|l'bbs url' M’ 








值 : |FORM. bbs tine E 
IRU M: 文本 ba | 
插入 后 ， 转 到 : index.php 














图 8-65 WE "i^i 


(30 选择 表单 执行 菜单 栏 上 “窗口 ”一 “行为 ”命令 ， 打 开 “ 行 为 ”面板 ， 单 击 “ 行 
为 ”面板 中 的 国 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “检查 表 单 ” 命 令 ， 打 开 “ 检 查 表单 ”对 话 
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框 ， 设 置 “ 值 ”和 “可 接受 ”范围 。 如 文本 bbs_email“ 值 ”设置 为 “必需 的 ”，“ 可 接受 ” 
为 “电子 邮件 地 址 ” 如 图 8-66 所 示 。 


input “bbs name" (KJ 

input “bbs email” [RisEmail) 
input “bbs url" 

textarea "bbs content" [R] 


(8: 必需 的 


Tes O 性向 东西 O mee 
© 电子 邮件 地 址 O mM | | 到 | | 





8-66 “检查 表单 ”对 话 框 


(4) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 完 成 bbs add.php 页 面 插入 记录 的 设置 。 
(5) 按 下 《F12〉 键 至 浏览 如 测试 一 下 。 首 先 打 开 bbs add.php 页 面 再 填写 表单 ， 填 写 表 


单 资料 如 图 8-67 所 示 。 


db uini - Hicrosoft Internet Explorer 
Hrn (x) Wo) GEOo) IR Mw 


QH- 5- dit ^x tI O Gi 
EHE 00) AE bct: 8T; 0.0, Libba bba whl php ] 5 tweckppmE woERdeED ds Qieun py 





PHP 论 坛 管理 系统 t E 


- w- E E E T E3 F3 
E | mM 
EIU TT "p n m - 
HFD: mH REM ug 
WA! ladmin 
E 














8-67 HERAA 





(6) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提交 ”按钮 ， 将 此 资料 发 送 到 bbs main 数据 表 中 。 
页 面 将 返回 到 BBS 讨论 系统 主页 面 index.php， 如 图 8-68 所 示 ， 表 示 发 布 新 主题 成 功 。 











Dao oo 5 s = 


TEREZE Hicròsoft Internet Explorer 
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回复 讨论 主题 页 面 bbs_reply php 的 设计 与 讨论 主题 内 容 页 面 的 制作 相似 ， 回 复 主题 是 将 
表单 中 填写 的 数据 插入 到 bbs. ret 数据 表 中 ， 页 面 设 计 效果 如 图 8-69 所 示 。 
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图 8-69 ”回复 讨论 主题 页 面 设计 效果 


CD. 由 于 在 讨论 主题 内 容 页 面 contenLphp 中 ， 设 定 有 传递 参数 bbs ID 〈 主 题 编 号 ) 会 
传递 到 这 一 页 面 ， 因 此 必须 先 将 这 个 参数 绑 定 到 一 个 命名 为 bbs main ID 的 隐藏 域 中 。 在 页 
面 上 插入 以 下 隐藏 域 ， 并 命名 为 bbs main ID， 并 定义 其 值 为 


<?php echo $bbs main ID ?> 


如 图 8-70 所 示 。 
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尾 性 
IN] ES iix: ih 
(BO) (Cris echo Soos mein D |A 











图 8-70 ”设置 隐藏 域 bbs_main_ID 的 值 
(20 Aag Me 按钮， 切换 到 代码 窗口 ， 将 如 下 的 代码 加 入 到 第 117: 


<?php 
$bbs_main_ID=strval($_GET['bbs_ID']); 
7» 


如 图 8-71 所 示 。 
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图 8-71 加 入 代码 
(3) 再 插入 一 个 隐藏 字段 bbs_ref_time， 绑 定 为 当时 的 时 间 。 


<?php 
date_default_timezone_set('Asia/Shanghai'); 
echo date(" Y-m-d"); 

po 


属性 面板 的 设置 如 图 8-72 所 示 。 


en 





区 E ei. h 
1B) phpdate default timezone, set rj 


图 8-72 设置 隐藏 区 域 值 
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(4) 在 bbs_reply.php 编辑 页 面 ， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行为 ”面板 中 的 
国 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 插 入 记录 ”命令 ， 在 “插入 记录 ”的 设 定 对 话 框 中 设 
S P. 
D 从 “连接 ”下 拉 列 表 框 中 选择 bbs 作为 数据 源 连 接 对 象 。 e 
2) 从 “插入 表格 ”下 拉 列 表 框 中 选择 bbs. ref 作为 使 用 的 数据 库 表 对 象 。 ja 
3) 在 “插入 后 ， 转 到 ”文本 框 中 设置 记录 成 功 添加 到 表 bbs_ref， 然 后 再 转 到 index.php —— 











网 页 。 
4) 在 “ 列 ” 列 选项 中 ， 将 网 页 中 的 表单 对 象 和 数据 库 中 表 bbs ref 中 的 字段 一 一 对 


设置 完成 后 ， 访 对 话 框 如 图 8-73 所 示 。 
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iB: En bbs. nain ID 
RTH: | 整数 
插 人 后 ， 转 到 : index. php 














图 8-73 设置 “插入 记录 ”对 话 框 


(5) 选择 表单 执行 菜单 “窗口 ”一 “行为 ”命令 ,打开 “行为 ”和 面板 ， 单 击 “ 行 为 ” 面 
板 中 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表 单 ” 命 令 。 打 开 “ 检 查 表单 ”对 话 框 ， 设 置 
文本 域 的 “ 值 ” 为 “必需 的 ”，“ 可 接受 ”为 “任何 东西 "其 中 bbs ref email 字段 为 “电子 
邮件 地 址 ” 如 图 8-74 所 示 。 





input "bbs ref name” - Œ) 


iR) 
textarea “bbs ref content" (R) 


i: |] eme 


TES O frfkp O 数字 
© 电子 邮件 地 址 局 数字 人 | | 到 | | 





图 8-74 设置 “检查 表单 ”对 话 框 
(6) 单 击 “ 确 定 ” 按 钮 ， 回 到 编辑 页 面 ， 这 样 就 完成 了 bbs_reply.php 页 面 插 入 记录 
的 设计 。 
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C) 按 下 《F12〉 键 至 浏览 费 测试。 首先 打开 首页 面 ， 选 择 其 中 任 总 一 个 讨论 主题 ， 进 
入 content.php 页 面 ， 在 content.php 页 面 单 击 “ 回 复 主 题 ” 转 到 回复 讨论 主题 bbs_reply.php 
页 面 ， 在 bbs reply.php 页 面 填写 表单 ， 填 写 表 单 资 料 如 图 8-75 所 示 。 


THT Rw) FE R IR Waow 
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PHP 论 坛 管理 系统 : 





8-75 ”填写 表单 资料 


(8) 填写 资料 完成 以 后 ， 单 击 “ 确 定 提 交 ” 投 钮 ， 将 此 资料 发 送 到 bbs ref 数据 表 中 。 
页 面 将 返回 到 BBS 讨论 区 系统 内 容 页 面 index.php， 和 再 单 击 主题 后 可 以 看 到 回复 ， 如 图 8-76 
所 示 ， 表 示 回 复 主 题 成 功 。 
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8-76 回复 主题 成 功 





_ Section_ 














BBS 论坛 管理 系统 的 后 台 管 理 比 较 重 要 ， 访 问 者 在 回复 主题 时 间 复 一 些 非法 或 者 不 文明 
的 信息 时 ， 管 理 员 可 以 通过 后 从 对 非法 或 不 文明 的 信息 进行 删除 。 


AXE nasiss o ， 


由 于 管理 页 和 面 是 不 允许 网 站 访问 者 进入 的 ， 必 须 受到 权限 管理 ， 可 以 利用 省 理 员 账 号 和 
管理 密 但 来 判 列 是否 有 此 用 户 ， 设 计 如 网 8-77 所 示 。 











A CrzXAÀpacheXhtdoczXbbszXadmin login. php* 


S EN 


和 和 


[CERES 


SIT x 143w B EK / 1 fÜ Unicode (UTF-8) .: 





8-77 “BBS 后 台 版 主 登录 页 面 ”设计 





其 详细 操作 步骤 如 下 。 

(OD 打开 后 台 版 主 登录 页 面 admin_login.php， 单 击 “ 应 用 程序 ”面板 群 组 中 “服务 器 行 
A" 面板 上 的 处 按钮， 在 弹出 的 菜单 中 选择 “用 户 身 份 验证 /登录 用 户 ” 的 命令 ， 在 打开 
“登录 用 户 ” 对 话 框 中 ， 设 置 为 如 果 不 成 功 将 返回 BBS 论坛 系统 主页 面 index.php， 如 果 成 功 
将 转向 后 台 版 主管 理 页 面 admin.php， 设 置 如 图 8-78 所 示 。 











从 表单 获取 输入 : forml 
用 户 名 字段 : username 
密码 字段 : password 
使 用 连接 验证 : bbs 
表格 : | admin 
用 户 名 列 : username 
密码 列 : password 















































如 果 登 录 成 功 ， 转 到 : admin. php 
器” 转 到 前 一 个 URL( 如 果 它 存在 ) 
dn ERE , $]: index.php | 
基于 以 下 项 限制 访问 : 9 Reque 

〇 OC 用 户 名 、 密 码 和 访问 级 别 

苹 职 级 别 自 : ID 























8-78 设置 “登录 用 户 ” 对 话 杠 
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(2) 选择 表单 ， 执 行 采 单 “ 窗 口 ” 一 “行为 ”命令 ， 打 开 “ 行 为 ”和 面板， 单 击 “行为 ” 
面板 中 的 外 | 按钮， 在 弹出 的 菜单 中 ， 选 择 “ 检 查 表单 ”命令 ， 打 开 “ 检 查 表单 ”对 话 框 ， 设 
置 username 和 password 文本 域 的 “ 值 ” 都 为 “必需 的 ”，“ 可 接受 ”为 “任何 东西 "” 如 图 
8-79 Bras. 





可 接受 ”任何 东西 O 数字 
O 电子 邮件 地 址 O 数字 从 | 008 | 





图 8-79 设置 “检查 表单 ”对 话 框 


(3) 单 击 “确定 ”按钮 ， 回 到 编辑 页 面 ， 现 在 后 台 版 主 登录 页 面 admin login.php 的 设 
计 与 制作 都 已 经 完成 ， 如 图 8-80 所 示 。 











A C:XÁpacheXhtdocsXbbsYXadmin login.php m 回 区 | 


Ur I2 





(body? CForméformi? — [lh |i) Qj 100€ — 4 51T x 147v B K / 1 £P Unicode (UTF-8) 


图 8-80 ”设置 完毕 的 厂 主 登录 页 面 


usc 后 台 版 主管 理 


BBS 论坛 管理 系统 的 后 台 版 主管 理 页 面 是 厂 主 由 登录 的 页 面 验证 成 功 后 所 转 到 的 页 面 。 
这 个 页 面 主 要 为 版 主 提供 对 数据 的 新 增 、 修 改 、 删 除 内 容 等 功能 。 后 侣 版 主管 理 页 面 
admin.php 的 内 容 设计 与 BBS 论坛 系统 主页 面 index.php 大 致 相同 ， 不 同 的 是 加 入 可 以 转 到 所 
编辑 页 面 的 链接 。 页 面 效 果 如 图 8-81 所 示 。 

CD 后 人 台 版 主管 理 页 面 admin.php 中 ， 动 态 显 示 部 分 和 index.php 是 一 样 的 ， 所 以 可 以 直 
接 将 index.php 保存 为 admin.php 页 面 ， 然 后 再 加 入 “修改 ”和 “删除 ”的 两 列表 格 。 每 个 讨 
论 主题 后 面部 各 有 一 个 “修改 ”按钮 和 和 “删除” 按钮， 它们 分 别 是 用 来 修改 和 删除 某 个 讨论 主 
题 的 ， 但 不 是 在 这 个 页 面 执 行 ， 而 是 利用 转 到 详细 页 面 的 方式 ， 另 外 打开 一 个 页 面 进行 相应 的 
操作 。 
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8-81 后 分 版 主管 理 页 面 的 设计 效果 
(2) 单 击 admin.php 页 面 中 的 “删除 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 图 8-82 
所 示 : 





del_title.php?bbs_ID=<?php echo $row. rs bbs['bbs ID']; ?> 
属性 


| 
E Ee IK Eie | 源 文 件 G) images/desle sif Goan] — ~v) 类 O| 天 
m | 高 由 | | HEO: Qo s ?g9- 


Aam laaan ”| Bew) — (v iem  |Nu€^A 
A) OOV e| — | Bá —  — gre 


8-82 ”设置 “链接 ”属性 
(3) 单 击 admin.php 页 面 中 的 “修改 ”按钮 ， 在 “属性 ”面板 中 设置 “链接 ”如 图 8-83 
Br: 
upd title.php?bbs ID-«?php echo $row rs bbs['bbs ID']; ?> 


尾 性 


—————————— Ó = 
a Ee ik — Ehe | 源 文 件 G)[inages/write eif logo ROD| — — — — v| 类 GO| 天 
I) ^ | Awhe | HEL) [upd title phpbb OGO B JW 


地 图 | amvev) | Bio ~ iE» EAE A 
RA) DO V xxem| | me) O loo 对 FW 


8-83 ”设置 “链接 ”属性 
(4) 由 于 讨论 区 的 管理 权限 是 属于 版 主 的 ， 因 此 必须 设 定 本 页 面 “ 限 制 对 页 访问 ”的 
服务 器 行为 。 单 击 “ 服 务 器 行为 ”面板 上 的 四 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 用 户 身份 验 
证 ”一 “限制 对 页 的 访问 ”命令 ， 打 开 “ 限 制 对 页 的 访问 ”对 话 框 ， 选 择 “ 用 户 名 和 密码 ” 
单 选 按钮 ， 如 果 访 问 被 拒绝 页 面 ， 将 转 癌 admin_login.php， 如 图 8-84 所 示 。 


限制 对 页 的 访问 








基于 以 下 内 容 进 行 限制 : C ”用户 名 和 密码 




















8-84 限制 对 页 面 的 访问 设置 
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susce 删除 讨论 页 面 


删除 讨论 页 面 del_title.php 的 功能 不 只 是 要 删除 所 指定 的 主题 ， 还 要 将 与 此 主题 相关 的 
回复 留言 从 资料 表 bbs ref 中 删除 。 页 面 设 计 效 果 如 图 8-85 所 示 。 
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图 8-85 ”删除 讨论 页 面 的 设计 戏 果 
许 细 操作 步骤 如 下 。 
(1) 打开 删除 讨论 页 面 del_titephp， 单 击 “ 应 用 程序 ”面板 群 组 中 “ 绑 定 ”面板 上 的 
上 出 | 按 钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 录 集 〈 查 询 )” 的 命令 ， 在 打开 的 “记录 集 ” 对 话 框 中 
单 击 “高 级 ”按钮 ， 进 入 记录 集 高 级 设 定 的 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL i& 
AJ, WME 8-86 所 示 。 
SELECT bbs main.*,bbs ref.* 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'"".Sbbs ID." 














Y 








: SELECT bbs main.*,bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref 
i - f 1 WHERE b ain. bbs ID 


N bbs main.bbs IlD-bbs ref.bbs main ID bs m 
'*$bbs ID. " 




















添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


dk ”预存 过 程 





8-86 改写 SQL 语句 





人 





(2) 上 图 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin.php 传递 过 来 的 参数 ， 因 此 
在 该 页 目 动 生成 的 PHP 代码 中 的 第 工行 加 入 如 下 的 变量 赋值 。 





$bbs ID-strval($ GET['bbs ID']; 


(3) 在 设 定 完 记 录 集 绑 定 后 ， 把 rs 记录 集中 的 字段 插入 到 del_title.php KEE, wK 
8-87 所 示 。 





"C: whpachevhtdoesAbbsvdel_title php 


| ”PHP 论坛 管理 系统 I 


i -E 


你 确定 册 除 此 标题 和 内 容 : 


{rs.bbs_title} 


{rs. bbs_content} ^ 
v 


确定 删除 


Copyright @ 2011 www. hbculture. com Inc. All rights reserved. WEZ F 














< u » 
table? <tr> <td> <form. .. > (table? <tr> <td> Qlabel?KCtextares...7] [RI Q 100€ — 4| T85 x 445v 82 K / 2 fb Unicode (UTF-8) — - 





8-87 ”字段 插入 全 del title.php 中 


(4) 在 页 面 中 插入 一 个 隐藏 字 段 bbs ID， 将 这 个 变量 绑 定 全 删除 讨论 页 面 del titlephp 
中 的 隐藏 区 域 bbs_ ID， 如 图 8-88 所 示 。 


IN] Eee [x det 
io) 多 








8-88 ”插入 字段 到 隐藏 域 中 


(5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del_title.php 页 面 加 入 “删除 记录 ”的 设置 ， 具 
体 的 设置 如 图 8-89 所 示 。 





首先 检查 是 天 已 定 兴 变量 : EHA m | 
连接 : bbs v 


表格 : bbs main wv 














xw. sis 


主键 值 : VRL 参数 v| bbs ID 


册 除 后 ， 转 到 : admin. php pls... 























8-89 ”设置 “删除 记录 ”对 话 框 
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单 击 “ 确 定 ” 按 钮 ， 完 成 删除 讨论 页 面 的 设置 。 


S50 | 修改 讨论 主题 


修改 讨论 主题 页 面 upd_title.php 的 功能 是 更 新 主题 的 标题 和 内 容 到 bbs. main 数据 表 中 ， 
页 面 设 计 如 图 8-90 所 示 。 


E c:Wapacheht docsbbsupd_title php 





iN 


CIPUE AE P. di 
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你 确定 修改 此 标题 和 











确定 修改 


Copyright @ 2011 www hbeulture.com Inc.All rights reserved. 论坛 之 家 
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8-90 ”修改 讨论 主题 页 面 效果 








操作 步骤 如 下 。 

(1) 打开 修改 讨论 主题 页 面 upd. title.php， 单 击 “ 绑 定 ” 面 板 上 的 固 按钮 ， 在 弹出 的 菜 
单 中 ， 选 择 “ 记 录 集 《得 询 )” 人 命令， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ” 投 钮 ， 
进入 记录 集 高 级 设 定 页 面 ， 将 现 有 的 SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-91 所 示 : 

SELECT bbs main.*,bbs ref.* 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'"".Sbbs ID." 























M 


: |SELECT bbs *, bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref 
n ur main. n. bbs ID= tb:  ref.bbs main; -ID WHERE bbs | main. bbs ID 
bbs ID." 























添加 到 SQL: 


SELECT 


WHERE 


ORDER BY 


dk ”预存 过 程 








8-91 改写 SQL 语句 














(2) 图 8-91 中 设置 了 一 个 名 为 $bbs_ID 的 变量 值 ， 即 是 admin.php 传递 过 来 的 参数 ， 因 
此 在 该 页 目 动 生成 的 PHP 代码 中 的 第 一 行 加 入 如 下 的 变量 赋值 。 





$bbs ID-strval($ GET[ bbs ID']); > 


(3) 在 设 定 完 记 录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 upd title.php 页 面 上 ， 如 
图 8-92 所 示 。 





V C: hpache\htdocs\bbs\upd_ title. php 


你 确定 修改 此 标题 和 内 容 : 


{rs.bbs_title} 


{rs. bbs_content} 











确定 修改 


Copyright @ 2011 waw. hbculture.com Inc.All rights reserved. 论坛 之 家 


< liii 
> <td> <form. . . > <table> tr? <td> Label? Ktextarea...7] O S) Q 100$ 4/721 x 430v 63 K / 2 fU Unicode (UTF-8) — - 


图 8-92 ”字段 插入 至 upd title.php 中 
(4) 在 页 面 中 搬入 一 个 隐藏 字段 bbs ID ， 将 这 个 变量 绑 定 至 修改 讨论 主题 页 面 
upd_title.php 中 的 隐藏 域 bbs_ID， 如 图 8-93 所 示 。 








AI parkeu 
bosm | EM) [php echo $row rsl bbs IY J; ?多 





图 8-93 ”插入 字段 到 隐藏 区 域 中 


(5) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 upd_title.php 加 入 “更 新 记录 ”的 设置 。 在 “更 
新 记录 ”对 话 框 中 ， 输 入 如 图 8-94 所 示 的 设置 。 


TA’ B: forni v 
连接 : bbs v 
更 新 表格 : D —— ' 


: [bbs ID' H 'FORM.bbs EA Ei 
'bbs title "à FORM. bbs giia Ex Ec 
"bbs c — Z. 5; HBE? bur 




















S (B: | FORM. bbs content v 
提交 为 : | 文本 vOe 


在 更 新 后 , HB: [admin ph | EJ 

















图 8-94 设置 “更 新 记录 ”对 话 框 










PHP 





(60 单 击 “ 确 定 ” 按 钮 ， 完 成 修改 讨论 主题 页 面 的 设置 。 


S 删除 回复 页 面 


删除 回复 页 面 del reply.php 功能 是 将 表单 中 的 数据 从 网 站 的 数据 表 bbs_ref 中 删除 。 其 


主要 目的 是 ， 管 理 员 对 一 些 不 文明 和 非法 的 回复 信息 进行 删除 。 其 页 面 设计 效果 如 图 8-95 
所 示 。 
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8-95 del reply.php 页 面 的 设计 效果 
其 详细 的 操作 步骤 如 下 。 


COD 打开 后 台 版 主管 理 页 面 admin.php 单 击 标题 ， 进 入 del replyphp 页 面 。 实 现 此 功能 
时 ， 只 要 在 标题 的 属性 栏 将 链接 到 的 页 面 参数 修改 为 del_reply.php 整 可 以 ， 如 图 8-96 Drs. 













属性 

ERO) 类 pisos am [| | 
bs mo EEO MESTAT oO Bg ~ 
国 4m KFORU v æv) | AGO] WREG [ — | 

m| nn] 


cj je  £&B(DSNA v| mOD| 40 wawo 
图 8-96 属性 链接 设置 


(2) 在 del reply.php 页 面 ， 单 击 “ 绑 定 ” 面 板 上 的 外 按钮 ， 在 弹出 的 菜单 中 ， 选 择 “ 记 
录 集 〈 答 询 )” 人 命令， 在 打开 的 “记录 集 ” 对 话 框 中 ， 单 击 “ 高 级 ”按钮 ， 进 入 记录 集 遍 级 
WER, KIAH SQL 语句 改 成 以 下 的 SQL 语句 ， 如 图 8-97 所 示 。 

SELECT bbs main.*,bbs ref.* 


FROM bbs main LEFT OUTER JOIN bbs ref ON bbs main.bbs ID-bbs ref.bbs main ID 
WHERE bbs main.bbs ID -'"".Sbbs ID." 








(QL*-Dreamweaver 动态 网 站 建设 从 入 门 到 精通 











(ms 可 (EX 








: [SELECT bbs main.*, bbs ref.* FROM bbs main LEFT OUTER JOIN bbs ref 
ON bbs m ain. bbs ID-bbs ref. bbs main ID WHERE bbs main.bbs ID F 





Dow 











数据 库 项 : EI 添加 到 SAL: 
A 视图 
d. ”预存 过 程 





图 8-97 改写 SQL 语句 





(3) 在 该 页 目 动 生 成 的 PHP 代码 中 的 第 1 行 加 入 如 下 的 变量 赋值。 


$bbs ID-strval($ GET['bbs ID']); 


(4) 在 设 定 完 记录 集 绑 定 后 ， 把 记录 集 rs 中 的 字段 插入 到 del reply.php WEE, 


8-98 所 示 。 


如 图 
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8-98 ”字段 插入 至 del reply.php 中 
C5) 在 页 面 中 插入 一 个 隐藏 字段 bbs ID， 将 这 个 变量 绑 定 全 删除 回复 页 面 del reply.php 
中 的 隐藏 区 域 pbs_ID， 如 图 8-99 所 示 。 


IN] parne 
av 多 








图 8-99 插入 字段 到 隐藏 域 中 
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(6) 完成 页 面 的 字段 布置 后 ， 接 着 要 在 del_reply.php 页 面 加 入 “删除 记录 ”的 设 定 ， 只 
要 在 “删除 记录 ”对 话 框 中 ， 输 入 如 图 8-100 所 示 的 设置 。 





首先 检查 是 否 已 定义 变量 : «[ | 
表格 : s re 























主键 列 : bbs ref ID v 数值 
ESRB: URL 和 参数 {v bbs ref ID | 


删除 后 ， 转 到 : admin. php 




















8-100 ”设置 “删除 记录 ”对 话 框 


Ax HI BBS 论坛 系统 的 开 友 制作 ， 读 者 可 以 任 信 学 习 a 到 的 知识 来 做 一 个 个 性 
化 的 论坛 ， 通 过 加 入 更 多 的 技术 ， 可 以 完成 更 强大 的 Web 程序 。 











第 性】 章 “PHP 网 上 购物 系统 前 台 


本 章 介 绍 一 个 使 用 PHP. 开发 的 大 型 电子 商务 网 站 的 建设 实例 。 网 上 购物 系统 是 由 专业 
网 络 技术 公司 开发 ， 是 拥有 产品 发 布 、 订 单 处 理 、 购 物 车 等 功能 组 合 而 成 的 复杂 动态 系统 。 
它 必 须 拥 有 会 员 系 统 、 碍 询 系统 、 购 物流 程 、 会 员 服务 、 后 人 台 管 理 等 功能 模块 ， 从 技术 角度 
来 说 ， 主 要 是 通过 购物 车 实现 电子 商务 功能 。 本 章 主 要 介绍 使 用 PHP 进行 网 上 购物 系统 前 
台 开 发 的 方法 ， 将 系统 地 介绍 网 上 购物 系统 的 设计 、 数 据 库 的 规划 以 及 津 用 的 儿 个 功能 模块 
前 台 的 开发 方法 。 








MATIE A 


本 草 主 要 掌握 以 下 知识 点 : 


网 上 购物 系统 的 功能 分 析 与 模块 设计 
网 上 购物 系统 数据 库 的 设计 搭建 
购物 车 首页 的 设计 

商品 相关 动态 页 面 设计 
商品 结算 功能 设计 
订单 查询 功能 设计 


Q Qul 
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_ Section _ 
网 上 购物 系统 分 析 与 设计 


网 上 购物 系统 是 一 个 比较 庞大 的 系统 ， 拥 有 会 员 系 统 、 碍 询 系统 、 购 物流 程 、 会 员 服 
务 、 后 台 管 理 等 功能 模块 。 为 了 能 系统 化 地 介绍 使 用 PHP 建设 电子 商务 网 站 的 过 程 ， 本 章 
将 模拟 一 个 实用 的 购物 网 站 的 建设 过 程 为 例 ， 来 详细 介绍 网 站 想 拥 有 一 个 网 上 购物 系统 必须 
做 哪些 具体 工作 。 


| 购物 系统 分 析 


商务 实用 型 网 站 是 在 网 络 上 建立 一 个 虚拟 的 购物 商场 ， 让 访问 者 在 网 络 上 购物 。 网 上 购 
物 以 及 网 上 商店 的 出 现 ， 避 免 了 挑选 商品 的 烦 开 过 程 ， 让 人 们 的 购物 过 程 变 得 轻松 、 人 快捷、 
方便 ， 适 合 现代 人 快 节奏 的 生活 需求 ， 同 时 又 能 有 效 地 控制 “商场 ”运营 的 成 本 ， 开 辟 了 
一 个 新 的 销售 渠道 。 本 实例 是 使 用 PHP-MySQL 直接 用 手写 程序 完成 的 实例 ， 完 成 的 首页 
如 图 9-1 所 示 。 






































图 9-1 开发 设计 的 网 上 购物 系统 首页 效果 


对 于 该 网 站 的 功能 说 明 如 下 。 

CD 采取 会 员 制 保证 交易 的 安全 性 。 

(2) 开发 了 强大 的 搜索 以 及 高 级 个 询 功能 ， 能 够 快捷 地 找到 感 兴 趣 的 丙 品 。 

(3) 会员 购 物流 程 : 浏览 、 将 商品 放 入 购物 车 、 去 收银 人 台 。 每 个 会 员 有 目 己 专用 的 购物 车 ， 
可 随时 订购 目 己 中 意 的 商品 、 结 账 完成 购物 。 购 物 的 流程 是 指导 编写 购物 车 系统 程序 的 主要 依据 。 

(4) 完善 的 会 员 中 心服 务 功能 : 可 随时 查看 账目 明细 、 订 单 明 细 。 

(50 设计 会 员 价 商品 展示 ， 能 够 显示 企业 近期 所 促销 的 一 些 会 员 价 商品 。 

(6) 人 性 化 的 会 员 与 网 站 留言 以 及 产品 评价 系统 ， 可 以 方便 会 员 与 网 站 管理 员 之 间 的 沟通 。 



































PHP 网 上 购物 系统 前 人 台 





CD 后 台 管 理 使 用 本 地 数据 库 ， 保 证 购物 订单 被 安全 、 及 时 、 有 效 地 处 理 。 强 大 的 统计 
分 析 功 能 ， 便 于 管理 员 及 时 了 解 财务 状况 、 销 售 状况 。 


SA | 功能 模块 分 析 


通过 对 系统 功能 的 分 机， 得 到 网 站 的 网 上 购物 系统 主要 由 如 下 功能 模块 组 成 。 

(1) 前台 网 上 销售 醒 基 。 指 客户 在 浏览 亏 中 所 看 到 的 、 可 和 直接 与 店主 面对面 的 销售 程 
序 ， 包 括 浏 览 商 品 、 订 购 商 品 、 碍 询 订 购 、 购 物 车 等 功能 。 

(2) 后 台数 据 录 入 模块 。 前 台所 销售 商品 的 所 有 数据 ， 其 来 源 部 是 后 台所 录入 的 数据 。 

G) 后 台数 据 处 理 功 能 模块 。 它 是 相对 于 前 台 网 上 销售 模块 而 言 ， 网 上 销售 的 数据 都 放 
在 铀 售 数据 库 中 ， 对 这 部 分 的 数据 进行 处 理 ， 是 后 台数 据 处 理 模块 的 功能 。 

(4) 用 户 注册 功能 模块 。 用 户 不 一 定 立 即 就 要 买 东西 ， 可 移 注 册 ， 任 何 时候 都 可 以 来 买 
东西 。 用 户 注 册 的 好 处 在 于 买 完 东 西 后 无 须 再 输入 一 大 堆 个 人 信息 ， 只 须 将 账号 和 密码 输入 
WEJ EA T o 
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随时 俘 询 账单 处 理 情况 ， 了 解 实时 的 物流 信息 。 

(60 会 员 留 言 模 块 。 客 户 能 及 时 反馈 信息 ， 管 理 员 能 在 后 台 实 现 回 复 的 功能 ， 真 正 做 到 
处 处 为 顾客 看 想 。 


SEDES 网 站 整体 规划 


在 制作 网 站 之 前 ， 首 先 要 把 设计 好 的 网 站 内 容 放 年 在 本 地 计算 机 的 便 盘 上 ， 为 了 方便 站 
凡 的 设计 及 上 传 ， 设计 好 的 网 页 都 应 存储 在 一 个 目录 下 ， 再 用 合理 的 文件 来 来 绾 理 文档 。 在 
本 地 站 点 中 应 该 用 文件 夹 来 合理 构建 文档 的 结构 。 首 先 为 站 点 创建 一 个 主要 文件 夹 ， 然 后 在 
其 中 再 创建 多 个 子 文 件 夹 ， 最 后 将 文档 分 关 存 储 到 相应 的 文件 夹 下 。 读 者 可 以 打开 光盘 中 的 
素材 ， 看 第 9 章 的 站 点 文档 结构 及 文件 夹 结构 ， 设 计 完 成 的 结构 如 网 9-2 所 示 。 
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图 9-2 网 站 文档 及 文件 夹 结构 
从 站 氮 规划 的 文件 夹 及 完成 的 页 和 面 出 发 ， 分 别 对 需要 设计 的 页 面 功能 分 析 如 表 9-1 所 示 。 
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hj xh Bp = x ft 
addgouwuche.php 
agreereg.php 
bottom.php 
changeuser.php 
changeuserpwd.php 
chkuser.php 
chkusernc.php 
conn/conn.php 
deleteall.php 
finddd.php 
findpwd.php 
serchorder.php 
function.php 
gouwuche.php 
gouwusuan.php 
highsearch.php 
index.php 
left.php 
logout.php 
lookinfo.php 
openfindpwd.php 
reg.php 
removegwc.php 
savechangeuserpwd.php 
savedd.php 
savepj.php 
savereg.php 
saveuserleaveword.php 
showdd.php 
showfenlei.php 
gonggao.php 
gonggaolist.php 
showhot.php 
shownewpr.php 
showpp.php 
showpl.php 
showpwd.php 
showtuijian.php 
top.php 
usercenter.php 


userleaveword.php 
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站 点 规划 的 页 面 功能 分 析 


主要 功能 
添加 订购 的 商品 到 购物 车 gouwuche.php 页 面 
同意 注册 页 面 
网 站 底部 版 权 
用 户 注 册 信 息 更 改 页 面 
更 改 登录 密码 页 面 
登录 身份 验证 页 面 
检查 昵称 是 否 被 用 文件 
conn 文件 夹 下 的 数据 库 连 接 文件 
删除 用 户 处 理 页 面 
订单 查询 页 面 
找 回 密码 功能 的 页 面 
租 找 到 商品 显示 页 面 
系统 调用 的 利用 函数 
购物 车 页 面 
收银 台 结 算 页 面 
高 级 查找 页 面 
网 站 购物 车 首页 
用 户 及 公告 系统 
用 户 退 出 页 面 
详细 商品 信息 
找 回 密码 问题 答案 页 面 
用 户 注册 开始 页 面 
购物 车 移 除 指定 商品 页 面 
更 改 用 户 密码 页 面 
保存 用 户 订单 页 面 
保存 商品 评价 页 面 
保存 用 户 注册 信息 
保存 用 户 留 言 员 和 面 
显示 详细 订单 页 面 
商品 分 类 显示 页 面 
显示 详细 公告 内 容 页 面 
公告 多 列 分 页 显示 
热门 商品 页 面 
最 新 商品 页 面 
商品 销售 排行 页 面 
商品 评论 分 页 显示 页 面 
用 户 找 回 的 密码 页 面 
推荐 商品 页 面 
网 站 顶部 导航 条 
会 员 中 心 页 面 
发 表 留 言 页 面 








EIE 
E 
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从 上 面 的 分 析 统 计 来 看 ， 该 网 站 前 合共 由 41 个 页 面 组 成 ， 几 乎 涉及 了 动态 网 站 建设 所 
有 的 功能 设计 。 


JA 购物 系统 数据 库 设 计 2 


网 上 购物 系统 的 数据 库 也 是 比较 庞大 的 ， 在 设计 的 时 候 需 要 从 使 用 的 功能 模块 入 手 ， 可 
以 分 别 创 建 不 同 命名 的 数据 表 ， 命 名 的 时 候 也 要 与 使 用 的 功能 命名 相配 合 ， 方 便 后 面相 关 页 
面 设计 制作 时 的 调用 。MySQL 数据 库 的 制作 方法 在 前 面 的 革 市 中 也 介绍 过 很 多 次 ， 本 曹 市 








国 dz (VAROMARC2S 





9-3 ££ db shop 数据 库 


SELLO 设计 数据 表 


数据 库 db_shop 里 是 根据 开发 网 站 的 几 大 动态 功能 来 设计 不 同 数据 表 的 ， 本 实例 需要 创 
建 8 个 不 同 的 数据 表 。 下 面 分 别 介 绍 这 些 数据 表 的 功能 及 设计 的 字段 要 求 。 

(1) tb admin 是 用 来 储存 后 台 管 理 员 的 信息 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 
A P: 


CREATE TABLE 'tb admin' ( 
id' int(4) NOT NULL DEFAULT '0', 
name' varchar(25) DEFAULT NULL, 
pwd' varchar(50) DEFAULT NULL, 
PRIMARY KEY (1d') 





















ENGINE=MyISAM DEFAULT CHARSET-2gb2312; 


WWW tb admin 数据 表 如 图 9-4 PZR. 


£& Table — [tb admin] — [db shop on localhost] 





PHP«*MySQL-*Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





Object Ed A | Properties | Eields | Indices | Triggers | Data | Dependencies | DDL | 








G db. shop on localhost [ v | | 
| asia 1 gg [INTEGER |4 0 
| E tb. admin w E Iname VARCHAR 25 0 


General mg 习 pwd VARCHAR 50 ü 


ig) Refresh 
学 Compile 
ĝo Grants on table 





©) Show SQL help 
(b Table Editor options 
由 [E] Restore defaut size 


Tools 


Es Truncate table 


Fields 


ES Add new field 
zd Edit selected field 








| Field Name Field Type Size Precision Mot Null Default 


图 9-4 后 台 管 理 员 表 tb admin 








(2) tb dingdan 是 用 来 储存 会 员 在 网 上 下 的 订单 的 详细 内 容 表 ， 在 MySQL 命令 栏 输入 


创建 该 数据 表 的 代码 如 下 : 


CREATE TABLE 'tb dingdan' ( 
ld int(4) NOT NULL AUTO INCREMENT, 
dingdanhao' varchar(125) DEFAULT NULL, 
Spc varchar(125) DEFAULT NULL, 
Slc varchar(125) DEFAULT NULL, 
'shouhuoren' varchar(25) DEFAULT NULL, 
Sex varchar(2) DEFAULT NULL, 
dizhi' varchar(125) DEFAULT NULL, 
'youbian' varchar(10) DEFAULT NULL, 
tel' varchar(25) DEFAULT NULL, 
emall varchar(25) DEFAULT NULL, 
'shff varchar(25) DEFAULT NULL, 
'"Zfff varchar(25) DEFAULT NULL, 
leaveword' mediumtext, 
tme varchar(25) DEFAULT NULL, 
xiadanren' varchar(25) DEFAULT NULL, 
zt varchar(50) DEFAULT NULL, 
total varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 

) 


ENGINE=MyISAM AUTO INCREMENT-z105 DEFAULT CHARSET-gb2312; 


设计 的 tb_dingdan 数据 表 如 图 9-5 所 示 。 











JA ETE Eu C. $95 GUD 于 证 


2630 [tb dingdan] 


ot ^ _ Properties Fields inces | Triggers Data | Dependencies DOL 
Field Name Field Type 
d NIEGEI 


| db shop co loceinost | vw. 





gaaaagaaaaaaaaagagaoaor 
EEEEEEEEEEEEEEEEDE 





9-5 HP i Hx tb dingdan 


(3) tb gonggao 是 用 来 保存 网 站 公告 的 信息 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 
代码 如 下 : 


CREATE TABLE 'tb gonggao' ( 
id int(4) NOT NULL AUTO INCREMENT, 
'title' varchar(100) DEFAULT NULL, 
'content' text, 
'time' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENTZ28 DEFAULT CHARSET-gb2312; 


设计 的 tb. gonggao 数据 表 如 图 9-6 所 示 。 


导 Table — [tb_gonggao] - [db shop on localhost] 











Object 
一 Field Type Size Preci... Mot... Default Comment 
| |H db shop on localhost [ v m " 
INTEGER 4 0 Null 


ic 0 
E tb_gonggao «B ^ VARCHAR 100 0 | [7] Nul 


cu - E content TEXT o 0 Om 
: 一 ,图 time VARCHAR 25 | | Nul 
; | | 

















[a] Refresh 

if Compile 

Qj» Grants on table 

éa Print 

Q9) Show SQL help 

(il Table Editor options 
回 Restore default size 

















色 9-6 网 站 公告 表 tb_gonggao 


(4) tb_leaveword 是 用 户 给 网 站 管理 员 留 言 的 数据 表 ， 在 MySQL 命令 栏 输入 创建 该 数 


据 表 的 代 公 如下: 


CREATE TABLE 'tb leaveword' ( 
ld int(4) NOT NULL AUTO INCREMENT, 
userid' int(4) DEFAULT NULL, 
title" varchar(100) DEFAULT NULL, 


'content' text, 
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tme' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENT-z16 DEFAULT CHARSET-gb2312; 


设计 的 tb leaveword 数据 表 如 图 9-7 所 示 。 


$ Table — [tb leaveword] — [db shop on localhost] 

Object Al | Properties | Fields | Indices || Triggers | Data | Dependencies | DDL | 
= Field Name Field Type Size Precisi... Not Null Default 
[4 db shop on localhost [ w 
Efi tb leaveword v : INTEGER 


cea "EE 
s |TEXT 
| [A] Refresh | i (VARCHAR 
学 Compile 5 



























































Qj» Grants on table 

ca Print 

Q9) Show SQL help 

他) Table Editor options 
[E Restore default size 























9-7 用 户 留 言 表 tb leaveword 
(5) tb pingjia 是 用 户 对 网 上 商品 的 评价 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 代码 
如 下 : 


CREATE TABLE 'tb_pingjia' ( 
ld int(4) NOT NULL AUTO INCREMENT, 
userid' int(4) DEFAULT NULL, 
'spid' int(4) DEFAULT NULL, 
'title' varchar(100) DEFAULT NULL, 
'content' text, 
tme' varchar(25) NOT NULL DEFAULT ", 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENTZ20 DEFAULT CHARSET-gb2312; 


设计 的 tb. pingjia 数据 表 如 图 9-8 所 示 。 
导 Table — [tb pingjia] — [db shop on localhost] 


[3 db shop on localhost [ v 
EF tb. pingjia v 


General - 


| [g] Refresh 
| g Compile 





















































VARCHAR 


Qj» Grants on table 

é% Print 

Q9) Show SAL help 

(5 Table Editor options 
回 Restore default size 


Tools 


Ef Truncate table 
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第 9 章 CNTEE 








(6) tb shangpin 是 商品 表 ， 购 物 系统 中 核心 的 产品 发 布 、 订 购 时 的 结算 都 要 调用 该 数据 
表 的 内 容 ， 在 MySQL 命令 栏 输 入 创建 该 数据 表 的 代码 如 下 : 


CREATE TABLE 'tb shangpin' ( * 
id int(4) NOT NULL AUTO INCREMENT, > 
'mingcheng' varchar(25) DEFAULT NULL, 
jianjie' mediumtext, 

'addtime' varchar(25) DEFAULT NULL, 
dengji' varchar(5) DEFAULT NULL, 
xinghao' varchar(25) DEFAULT NULL, 
tupian' varchar(200) DEFAULT NULL, 
'shuliang' int(4) DEFAULT NULL, 

cishu int(4) DEFAULT NULL, 

tuijian' int(4) DEFAULT NULL, 

typeid' int(4) DEFAULT NULL, 
'huiyuanjia' varchar(25) DEFAULT NULL, 
'shichangjia' varchar(25) DEFAULT NULL, 
pinpai' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENTZ222 DEFAULT CHARSET-gb2312; 


设计 的 tb_shangpin 数据 表 如 图 9-9 所 示 。 


也 Tabhlr ~ [th_zhangpin] ~ [dbh_ahop on localhost) 
objeet Ig A  properbes | Eds indices  Trgoers Data | Dependercies | DOG 
Field Name Feld Type ue Precisi.,, Not Mg Detout 
iE INTEGER " Ô 
dr; tb shengen El D] rnirggcheng VARCHAR |25 


G al AS jd] eese MEDIUUMTEXT O 
j|] ninar VARCHAR 


到 Retresh jd] dene VARCHAR 
Core 加 :noheo VARCHAR 
Qi» Granis on tatie I| tupinn VARCHAR 
. Print D] siang INTEGER 


| dh, shop on benhos |. ve 


X 


úh 


-ih 


- 
«4j Show SOL help t] ashu INTEGER 
tujan INTEGER 
(d; Takie Editor options ij vu» 
U] tvpesd NTEGER 
FA Restore deim sime 
D] huueees VARCHAR 


4 4 P» any 





TEN. 





Olole Olola Olola olo c o 


| shichangim VARCHAR 
d] pnpa VARCHAR 


Uu 


Dag Truncate takie 


ij Add new neid 


(B) Edit selected field 





图 9-9 商品 表 tb shangpin 
(7) tb_type 是 商品 的 分 类 表 ， 在 MySQL 命令 栏 输入 创建 该 数据 表 的 代码 如 下 : 


CREATE TABLE 'tb_type' ( 
id int(4) NOT NULL AUTO INCREMENT, 
typename' varchar(25) DEFAULT NULL, 
PRIMARY KEY (1d') 


) 
ENGINE=MyISAM AUTO INCREMENT-Z28 DEFAULT CHARSET-gb2312; 


WWW tb type 数据 表 如 图 9-10 所 示 。 





I Table ~ [th type] ~ [db shop om lacnlhozt ] 


Object a ^ properties | [ekis | indices | Triggers | Data | Dependencies DOC. 


— ` Fiski Name Fiki Type Sire — Precis — Not Nud Oeinut Comment 
[J do shop on locsihost |. se 


EG type 





v 
General 5 
| A) Retresh 
Jf Compie 
Qi» Granis on table 


9-10 商品 分 类 表 tb type 


(8) tb user 是 用 来 保存 网 站 会 员 注册 用 的 数据 表 ， 在 MySQL 命令 栏 输 入 创建 该 数据 表 


的 代码 如 下 : 


CREATE TABLE 'tb user ( 
ld int(4) NOT NULL AUTO INCREMENT, 
name' varchar(25) DEFAULT NULL, 
pwd' varchar(50) DEFAULT NULL, 
dongjie' int(4) DEFAULT NULL, 
'email' varchar(25) DEFAULT NULL, 
'sfzh' varchar(25) DEFAULT NULL, 
tel' varchar(25) DEFAULT NULL, 
qq varchar(25) DEFAULT NULL, 
'tishi' varchar(50) DEFAULT NULL, 
'huida' varchar(50) DEFAULT NULL, 
'dizhi' varchar(100) DEFAULT NULL, 
youblan varchar(25) DEFAULT NULL, 
regtime' varchar(25) DEFAULT NULL, 
truename' varchar(25) DEFAULT NULL, 
pwdl varchar(50) DEFAULT NULL, 
PRIMARY KEY (1d') 

) 

ENGINE=MyISAM AUTO INCREMENT-245 DEFAULT CHARSET-2gb2312 


设计 的 tb_user 数据 表 如 图 9711 PTR o 


| RJ [tb urer] ldb_sbep om localhost] 


AG 


DIDI D ODDO CoEICCoUBIE 


EEEE EEEE EEEE EEEE 


Ee 
Bols dood do als dal 





9-11 网 站 会 员 注 册 表 tb user 
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上 上面 设计 的 数据 表 属 于 比较 复杂 的 数据 表 ， 数 据 表 之 间 主 要 通过 产品 的 类 别 ID 关联 ， 
建立 网 站 所 需要 的 主要 内 容 信息 ， 都 能 储存 在 数据 库 里 面 。 


J22 定义 购物 车 站 点 J © 


定义 购物 车 系统 站 点 的 具体 操作 步骤 如 下 。 
(C1) 首先 在 CAApacheMitdocs 路 径 下 建立 shop 文件 来， 如 图 9-12 MaR, KENNA E 
的 PHP 程序 文件 都 将 放 在 该 文件 夹 下 。 


QAE- O- T Dusk Dirx |E 
地 址 0) [^ C: XApache*htdocs 














XIAEYPIXÉES e 


m] 重 命名 这 个 文件 来 
让 移动 这 个 文件 来 


复制 这 个 文件 来 
e REST SCHECNGRSI 
e 


i 共享 此 文件 夹 


O 以 电子 邮件 形式 发 送 
该 文件 来 内 的 立 件 
K 删除 这 个 交 件 夹 








ME 1 个 对 象 





图 9-12 建立 站 点 文件 夹 shop 
(2) 打开 Dreamweaver CS $.35， 选 择 荣 单 栏 中 的 “站 点 ”一 “管理 站 点 ”命令 ， 打 开 
“管理 站 点 ”对 话 框 ， 如 图 9-13 所 示 。 


|Dw | enm -| El OQ ove CEES 





打开 最 亚 的 项 目 
TA bharti rapi. php. 
"ED Wahl tile phe 
TU benimi pip 
T esie mpi php 


kz 


Sio EA pe gp p p got po pl 


[or Cana 
IAE | rip mbe frer rel bbr uie]: 
LISA 
LIRARE es 








9-13 “管理 站 点 ”对 话 框 


(3) Hab “新 建 ” 按 钮 ， 打 开 “ 站 点 设置 对 象 ”对 话 框 ， 进 行 如 下 参数 设置 。 
“站 点 名 称 ” shop. 















'PHP*MvySQL-4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





“本 地 站 点 文件 来” — CAApacheMtdocsNshop. 
如 图 9-14 所 示 。 


MEAME shop 
eamweaver WAER P RERO PEE Sr PERDERE E Rr. 


ERES BA. BRIDE LS RA 
x. HETET THERN ATH web FRIIRSERE ERR IER, 


Ur BT ELE BEES Dreamweaver W AiR EATHAR. 
H aa: shoo ! 
2k Het inb: [ C Vapachelhidocs hop 














几 9-14 建立 shop 站 点 


(4) 单 击 列表 框 中 的 “服务 器 ”选项 ， 并 单 击 “ 添 加 服务 器 ”按钮 薄 |， 打 开 “ 基 本 ” 
选项 卡 ， 进 行 如 图 9-15 所 示 的 参数 设置 。 

“服务 堪 名 称 ” shop。 

“连接 方法 ”本 地 /网 络 。 

“HRE aLI”: CNApacheMtdocs V. 

“Web URL”: http://127.0.0.1/shop/. 


DRAE shop 





























图 9-15 RA “IA” WWR 





(5) 设置 后 再 单 击 “ 高 级 ”选项 卡 ， 打 开 “ 高 级 ”服务 器 设置 对 话 框 ， 单 击 “ 维 护 同步 
信息 ” 复 选 按钮 ， 在 “服务 器 模型 ”下 拉 列 表 项 中 ， 选 择 PHP MySQL 表示 是 使 用 PHP 开发 
的 网 页 ， 其 他 的 保持 默认 值 ， 如 图 9-16 PTR. 


站 点 设置 对 锚 php 











^» mE Vemm 
口 Re Osee LRUES ES 
L] BI XCPERR HITS 





Rigt: 
eT MEE: 


semn noma — 3] 








图 9-16 设置 “高 级 ”选项 卡 
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(6) 单 击 “保存 ”按钮 ， 返 回 “ 服 务 器 ”设置 对 话 框 ， 再 单 击 选择 “测试 ” 复 选 按钮 ， 
如 图 9-17 所 示 。 





ETE Web 上 的 nm. Worse WR 
务 提供 商 qon) T Web 


WR Eu TER i ， OTERETEESRUSAN. TO IEEE web 并 发 








9-17 设置 “服务 器 ”参数 


单 击 “保存 ”按钮 ， 则 完成 站 点 的 定义 设置 。 完 成 Dreamweaver CS 5.5 测试 shop 网 页 
的 网 站 环境 设置 。 


Seer 数据 库 连接 


数据 库 设 计 之 后 ， 需 要 将 数据 库 连 接 到 网 页 上 ， 这 样 网 页 才能 调用 数据 库 和 储存 相应 的 
信息 。 用 PHP 开发 的 网 站 ， 一 般 将 数据 库 连 接 的 程序 代码 文件 命名 为 conn.php。 在 站 点 文 
件 夹 创建 conn.php 空白 页 面 ， 按 如 图 9-18 所 示 输 入 数据 库 连 接 代码 。 


四 C: \Apachethtdocs\shopiconniconn. php. (XHTML) -0x 
E 








r 


nn=mysql_connect ("localhost"”, “root”, “admin”) or die( 

FUP) mysql. error); 

mysql select db("db shop',$conn) or die ("$ti Eib lR". 
nysql error(): 

mysql query("set character set gb2312"); 

mysql query("set names gb2312"); 
?> 
| 


E E 


四 
y 


rn 


«« 








1KY1 秒 简体 中 娘 (GB2312)  - 


图 9-18 输入 数据 库 连 接 代码 
对 于 本 连接 的 程序 说 明 如 下 : 


<?php 

$conn=mysql_connect("localhost","root","admin") or die( 25315 PE Hg 2$ s XE Beth vx" mysql. error()); 
/设置 数据 库 连 接 ， 本 地 服务 器 ， 用 户 名 为 root， 密 码 为 admin， 如 果 连 接 错 误 调 用 mysql error 
PRA. 





mysql select. db("db. shop",$conn) or die(" 数 据 库 访 问 错误 ".mysqlL_errorO); 
/连接 db. shop 数据 库 ， 如 果 连 接 错 误 调 用 mysql. error. 
mysql query("set character set gb2312"); 
mysql query("set names gb2312"); 








i 


ema m 


^ PHP 
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// 设 置 数 据 库 的 字体 为 gb2312 即 中 文 简体 。 


2> 


读者 使 用 时 如 末 需 要 更 改 数据 库 名 称 ， 上 只 需要 将 该 页 和 面 中 的 db_shop 做 相应 的 更 改 即 可 
实现 ， 同 时 用 户 名 和 密码 和 在 本 地 安 朔 的 用 户 名 和 密码 要 保持 一 致 。 


po] ub E Da 动态 功能 



































对 于 一 个 网 站 系统 来 襄 ， 需 要 一 个 主页 面 来 给 用 户 进 行 注 册 、 搜 索 需 要 订购 的 商品 、 网 
上 浏览 商品 等 操作 。 实 例 的 首页 index.php 主要 由 fontcss. top.php. left_menu.php、 
bottom.php 等 共 4 个 二 级 页 面 组 合 而 成 。 本 小 节 介 绍 包 括 index.php 在 内 的 5 个 页 面 的 设计 。 


-31 网 站 的 样式 表 











任何 网 站 如 果 想 达到 美观 的 效果 ， 痢 是 要 经 过 专业 的 网 页 布局 设计 。 实 例 按 传 统 的 电子 
商务 网 站 布局 方式 进行 布局 ， 文 字样 式 的 美化 设计 是 使 用 样式 表 来 直接 设计 的 ， 实 例 的 样式 
表 保 存在 css 文件 夹 下 。 

(I) 运行 Dreamweaver CS 5.5 软件 ， 打 开 和 制作 到 这 一 步 的 站 点 文件 来 。 执 行 末 单 “ 文 
件 ” 一 “新 建 ” 命 令 ， 打 开 “ 新 建文 档 ” 对 话 框 ， 选 择 “ 罕 白 页 ”选项 卡 中 “页 面 类 型 ”下 
拉 列 表 框 中 的 CSS， 然 后 单 击 “ 创 建 ” 按 钮 创建 新 页 面 ， 如 网 9-19 所 示 。 在 网 站 css 目录 中 
新 建 一 个 名 为 font.ess 的 网 页 并 保存 。 





A zen 
A cus 
E auream 
ri coppa 


EJ xu TI EUN iss) Joni 





| «won | [mesar] 


图 9-19 创建 css 文件 


(20 进入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 创建 代码 删除 ， 然 后 加 入 如 下 代码 : 


A:link { 
COLOR: 2006699; TEXT-DECORATION: none 
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A:visited { 
COLOR: #006699; TEXT-DECORATION: none 
j 


A:active { ~Y 
COLOR: #006699; TEXT-DECORATION: none ©) 
} 
A:hover { 
COLOR: #000000 
} 
BODY { 
margin-top: 0px; 
} 
TD,TH { 
FONT-SIZE: 12px; COLOR: #006699; 
} 
/网 页 的 链接 及 基础 属性 。 


.buttoncss { 





"onc 


font-family: "Tahoma", "宋体 "; 
font-size: 9pt; color: 44003399; 
border: 1px #003399 solid; 
color:006699; 
BORDER-BOTTOM: #93bee2 1px solid; 
BORDER-LEFT: #93bee2 1px solid; 
BORDER-RIGHT: #93bee2 1px solid; 
BORDER-TOP: #93bee2 1px solid; 
background-color: #e8f4ff; 
CURSOR: hand; 
font-style: normal ; 
j 
inputcss { 
font-size: Opt; 
color: #003399; 
font-family: "R"; 
font-style: normal; 
border-color: 493BEE2 #93BEE2 #93BEE2 #93BEE2 ; 
border: 1px #93BEE2 solid; 
j 
inputcssnull { 
font-size: Opt; 
color: #003399; 
font-family: "宋体 "; 
font-style: normal; 
border: Opx #93BEE2 solid; 
j 
.scrollbar( 
SCROLLBAR-FACE-COLOR: 4£FFDD22; 





/"PHP- 
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FONT-SIZE: Opt; 
SCROLLBAR-HIGHLIGHT-COLOR: £69BC2C; 
SCROLLBAR-SHADOW-COLOR: 加 9BC2C; 
SCROLLBAR-3DLIGHT-COLOR: £69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff; 
SCROLLBAR-TRACK-COLOR: £69BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


j 


.scrollbar( 
SCROLLBAR-FACE-COLOR: 4£FFDD22; 
FONT-SIZE: Opt; 
SCROLLBAR-HIGHLIGHT-COLOR: £69BC2C; 
SCROLLBAR-SHADOW-COLOR: £269BC2C; 
SCROLLBAR-3DLIGHT-COLOR: £69BC2C; 
SCROLLBAR-ARROW-COLOR: #ffffff; 
SCROLLBAR-TRACK-COLOR: £269BC2C; 
SCROLLBAR-DARKSHADOW-COLOR: #69BC2C 


} 
/网 页 表单 对 象 的 样式 设置 


通过 上 面 样式 文件 的 建立 ， 可 以 将 整个 网 站 的 样式 统一 ， 起 到 美化 整个 网 站 的 效果 。 
| 建立 搜索 导航 ) 


导航 频道 是 网 站 建设 中 很 重要 的 部 分 ， 通 各 情况 下 ， 一 个 网 站 的 页 面 会 有 几 十 个 ， 更 大 
型 一 点 的 可 能 会 达到 几 千 个 甚至 几 万 个 ， 每 个 页 面 都 会 有 导航 栏 。 但 是 ， 在 网 站 后 期 维护 或 
者 需要 更 改 的 时 候 ， 这 个 工作 量 就 会 变 得 很 大 。 所 以 为 了 方便 ， 通 常 都 会 把 导航 栏 开 发 成 单 
独 的 一 个 页 面 ， 然 后 让 每 个 页 面 都 单独 调用 它 。 这 样 当 需要 变更 的 时 候 ， 只 要 修改 导航 栏 
这 一 个 负面， 其 他 的 页 面目 动 残 被 更 新 了 。 实 例 创 建 的 市 搜索 功能 的 导航 频道 ， 如 图 9-20 
所 示 。 
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图 9-20 ”搜索 导航 频道 


这 里 制作 的 步骤 如 下 。 
(1) 在 Dreamweaver CS 5.5 中 执行 菜单 “文件 ”一 “新 建 ” 命 令 ， 打开“ 新 建文 档 ” 对 
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话 框 ， 选 择 “ 室 白 页 ”选项 卡 中 “页 面 类 型 ”下 拉 列 表 框 中 的 PHP 选项 ， 在 “布局 ”下 拉 

列表 框 中 选择 “无 ”选项 ， 然 后 单 击 “ 创 建 ” 按钮 创建 新 页 面 ， 在 网 站 根 目录 下 新 建 一 个 名 

为 top.php 的 网 页 并 保存 。 | 
(2) 再 单 击 “ 显 示 代 码 视图 ”选择 [fa 掖 钮 ， 进 入 代码 视图 窗口 ， 将 里 面 所 有 的 默认 G) 

创建 代码 删除 ， 然 后 加 入 如 下 代码 ; 











<?php 
session start(); 
include("conn/conn.php"); 
?>/ 调 用 session 函数 ， 并 调用 conn.php 数据 库 链 接 文件 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 电 子 商 务 网 站 </title> 
<link rel="stylesheet" type="text/css" href2"css/font.css"» 
</head> 
<body> 
<table width="766" border="0" align="center" cellpadding="0" cellspacing="0"  background- 
"images/bannerdi.gif"> 
<tr> 
<td colspan="3" valign="bottom"> «table width="766" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
<tr> 
«td width="224" height="83">&nbsp; </td> 
<td align="right"> <p>&nbsp;</p> 
<table height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
«form name="form" method="post" action="serchorder.php"> 
<tr> 
«td widthz" 81" height="30" align="right"> &nbsp;</td> 
<td widthz" "500" height-''30" valign='"''middle" ><div alignz"left'"» &nbsp;<span class="'style4"'> 
«img src="'images/biao.gif" width="16" height="21">&nbsp; 输 入 关键 词 : </span> 
«input type="text" name="name" sizez'25" class-z'inputcss" style="background-color:#e8f4ff " 
onMouseOver="'this.style.backgroundColor="#ffffff""" 
onMouseOut='" this.style.backgroundColor='#e8f4 伦 …> 
«input type="hidden" name="jdcz" value="jdcz"'> 
«input name-"'submit" type="submit" class-" buttoncss" value='"" 搜 索 "…> 
<input name-"'button" type-'button'" class-'"buttoncss" onClick-z"javascript:window.location- 
'highsearch. php';" value=" 高 级 搜索 "> 
</div> </td> 
</tr> 
</form> 
</table> </td> 
</tr> 
</table> </td> 
</tr> 
<tr> 
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<td widthz"568" helght= 32"  bgcolorZ"*FFFFFF'»&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;«a href= 
"index.php"» H W «/a» &nbsp;| «a href="shownewpr.php"> 最 新 上 架 </a> | <a hrefz"showtuijian.php"» 
推荐 产品 </a> | «a hrefz"showhot.php"»2A1 ] j^ i </a> &nbsp;|&nbsp;«a href-"showfenlei.php"» ^ im 
4] 2S «la» &nbsp;|&nbsp;«a href="usercenter.php"> 用 户 中 心 </a>&nbsp;|&nbsp;<a href-"finddd.php"» 
订单 查询 </a>&nbsp;|&nbsp;<a href="gouwuche.php"> 购 物 车 </a></td> 
«td width="121" align="center" bgcolor="#FFFFFF"> 
<?php 
ifí$ SESSION([username]!2")( 
echo "用 户 :$_ SESSION[username DUGHIH fat" ; 
j 
2» 
</td> 
«td widthz" 77" bgcolorZ 4FFFFFF"*» 
<?php 
if($_SESSION[username]!=""){ 
echo "<a href='logout.php'> 注 销 离 开 </a>"; 
} 
7> 
</td> 
</tr> 
</table> 


上 述 代码 中 加 黑 部 分 为 搜索 功能 的 程序 。 | 
(D 加 入 代码 后 ， 就 会 发 现在 编辑 文档 窗口 中 ， 多 了 一 个 PHP 代码 占 位 符 W, 
如 图 9-21 所 示 。 


EE 


Ro TT TT PT DSYSDSUTUECUECUNESMPSUECUESGUMECUESUESUPSO DS) STO TX. 


ISSSSSSSASSASSSSASAAAAAAAAAAAASASAASA NAA SANA SANA SANA SANA AA NAA SANA SANA SANA AAA AAA AAA AAA ASA SA SANA AAA AAA SANA NN 


首 ”页 | EMER | 推荐 产品 | 热门 产品 | 产品 分 类 | 用 尸 中 心 | 订单 查询 | 购物 车 : pp Jug 


Soepssssssssssocssssccoccooscosssssssossesssssossooccoccoscesssscssssscsecscosseocecooccesossossssssessecossecceccecocssssssseccssccsseccccceccoccoccessossceseoesscsccsscooccccccccccceshoscsocoscecccecoccee 


图 9-21 HERRI EBERT 


最 后 保存 制作 的 页 面 ， 按 下 (F12) 快捷 键 ， 即 可 以 在 IE X aP ASARRE 
BUSCAR. 


— 二 m—mÓ————————————————— ——  ———— Y '/—— —————— —— — Üá— 


用 户 和 新 闻 显 示 


在 index.php 页 和 面 中 的 “产品 信息 ”栏目 里 面 ， 如 果 不 加 入 动态 功能 ， 则 只 能 显示 原来 
设计 的 静态 文字 。 如 果 想 调用 建立 的 shop 数据 库 中 “新 闻 表 ”里 面 的 新 闻 数 据 ， 并 且 能 够 
显示 最 新 的 10 条 信息 ， 如 何 用 PHP 进行 连接 和 处 理 呢 ? 

下 面 就 详细 介 绍 该 功能 的 开发 办 法 ， 制 作 步 又 如 下 。 

C1) 为 了 能 够 实现 页 面 的 调用 ， 需 要 首先 打开 数据 库 db shop 文件 ， 然 后 再 打开 
tb gonggao 数据 表 ， 加 入 一 些 数据 ， 如 图 9-22 Brzn. 











£ Table — [tb gonggao] — [db shop on localhost] 


Object ME A| | Fields | Indices | Triggers | Data |Description | DDL | 


HENCE. 

















| [3 db shop on localhost [ Y 
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«^ Commit transaction 
3€ Rollback transaction 
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Explorer | Grid View | Form View 
85] Fields (4) ^ MIo1oo0 
9-22 ”加 入 数据 


(2) 创建 left menu.php 页 面 ， 然 后 在 <head> 代 人 码 之 前 ， 加 入 调用 数据 库 连 接 页 面 
conn.php 的 如 下 命令 : 


<?php include("Conn/conn.php");?» 





加 入 后 简单 地 设计 一 下 用 户 系统 和 新 闻 公 告 两 个 功能 的 显示 效果 ， 设 计 完 成 后 编辑 文档 
窗口 ， 如 图 9-23 所 示 。 


T C: hpachevhtdaoesvshopAleft_merm. php (XHTML) 4Lx 





(R| 100% v568 x 347v 8 K / 1 秒 | 简体 中 文 6562312) 





9-23 设计 用 户 系统 和 新 闻 公 告 页 和 的 显示 效 采 








(3) 用 户 系 统 的 显示 界面 是 提供 给 用 户 登录 、 注 册 以 及 找 回 密码 的 功能 ， 具 体 的 注册 和 
找 回 密码 的 功能 将 在 下 一 市 介绍 ， 这 里 重点 介绍 使 用 PHP 实现 验证 人 码 随 机 调用 并 显示 为 数 
子 的 功能 程序 如 下 : 


<?php 
$num=intval(mt_rand(1000,9999)); 

/使 用 到 了 mt rand O 函数 调用 介 于 1000—9999 的 任意 一 个 数字 。 
for($i=0;$i<4;$i++){ 


echo "<img src=images/code/".substr(strval($num),$i,1).".gif>"; 









PHP+ 

















} 
/调用 images/code/ 文 件 夹 下 的 随机 字母 图 乒 ， 并 显示 成 4 位 数 。 
iod RIP 
该 程序 能 够 实现 如 图 9-24 所 示 的 随机 显示 图 片 验 证 但 数字 BP: 
的 效果 。 - Ir 
(4) 用 户 输入 用 户 名 和 密码 ， 并 单 击 “提交 ”按钮 后 ， 要 将 Bum sm 
输入 的 数据 传递 到 chkuser.php 页 面 进行 登录 验证 。 
AR F: 图 9-24 显示 验证 码 效果 


«form name="form2" method="post" actionz"chkuser.php" onSubmit="return chkuserinput(this)"> 


说 明 : 

该 段 代码 包含 了 两 个 意思 ， 第 一 个 action="chkuser.php" 意 思 是 转 到 chkuserphp 页 面 进行 验 
证 ; 第 二 个 onSubmit="return chkuserinput(this)" 意 思 是 直接 调用 JavaScript 的 chkuserinput(this) 进 
行 数据 输入 的 验证 ， 即 通常 在 提交 表单 时 ， 要 验证 一 下 输入 的 数据 是 否 为 空 ， 输 入 的 数据 格 
式 是 否 符 合 要 求 。 调 用 的 程序 如 下 : 


<script language="JavaScript"> 
function chkuserinput(form){ 


"tt 


if(form.username.value--"")( 
alert(" 请 输入 用 户 名 !"); 
form.username.select(); 
return(false); 
} W 如 果 用 户 名 没 输入 ， 则 提示 “请 输入 用 户 名 ! ” 
if(form.userpwd.value--"")( 
alert(" 请 输入 用 户 密 人 码 !"); 


form.userpwd.select(); 





return(false); 
} W 如 果 用 户 密码 没 输入 ， 则 提示 “请 输入 用 户 密码 !” 
if(form.yz.value==""){ 

alert(" i555] A AEA 1"); 


form.yz.select(); 











return(false); 

} W 如 果 用 户 验 证 人 码 没 有 输入 ， 则 提示 “请 输入 验证 人 码 !1” 
return(true); 

} 
</script> 








(5) 在 主页 的 “新 闻 公 告 ”显示 的 数据 要 实现 的 效果 是 调 出 新 闻 的 标题 ， 在 单 击 标题 时 
能 打开 详细 页 面 ， 调 出 5 条 数据 。 下 面 将 所 有 的 代码 列 出 。 


<?php 

$sql=mysql_query("select * from tb_gonggao order by time desc limit 0,5",$conn); 
/按时 间 顺 序 从 tb_gonggao 数据 表 中 调用 5 条 数据 
$info=mysql_fetch_array($sq]); 
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if($info==false){ 

2 
<tr> 
«td height="20" align="center"> 暂 无 狐 闻 公告 1</td> 
</tr>// 如 果 没 有 数据 则 显示 为 “ 暂 无 狐 闻 公告 ! ” 
<?php 
j 
else{ 

do( 

2» 
<tr> 

<td height="20"><div align="center"> 

<table width="180" 

<tr> 
<td width="16" height="5"><div 
height="12"></div></td> 

<td width="164" height="24"><div 
$info[id];?>"> 

<?php 

echo substr(Sinfo[title],0,24); 

if(strlen(Sinfo[title])» 24) ( 
echo "..."; 


align="center"> «img 


align="left"> <a 





src-"images/circle.gif" 


href2"gonggao.php?id-«?php 





PHP 网 上 购物 系统 前 台 





border="0" align="center" cellpadding="0" cellspacing="0"> 


width="11" 


echo 





} /调用 新 闻 标 题 并 控制 显示 的 子 符 数 为 24， 如 果 标 题 比 较 长 则 显示 为 .… 


2» 
</a> </div></td> 
</tr> 
</table> 
</div></td> 
</tr> 
<?php 
j 
while(Sinfo2mysql fetch, array($sql)); 
j 


2» 


(6) 在 下 浏览 器 中 浏览 到 制作 的 调用 数据 的 结果 ， 
果 如 图 9-25 所 示 。 

in AH: 

如 此 轻易 就 实现 了 数据 库 的 调用 、 查 询 以 及 显示 操作 ， 读 者 会 
发 现 PHP 动态 网 页 的 开发 并 不 是 很 难 ， 只 需要 掌握 简单 的 代码 即 
可 以 实现 。 在 下 面 的 所 有 其 他 功能 区 域 都 是 采用 调用 、 条 件 查询 、 





基体 效 


绑 定 显示 、 关 闭 数据 库 这 样 一 个 相同 的 操作 步骤 来 实现 的 。 


一 





JA 
JA s 


网 站 实现 在 线 购物 ， 一 般 都 是 通过 用 户 上 自身 登录 、 浏 


| p = — Y 
产品 的 动态 展示 J 


用 户 系统 
RP: 
TH: 
验证 : 3541 
提 变 | 注册 找 回 密码 
新 闻 公告 : 更 多 


» 我 国 纸 业 三 大 热点 值得 关注 

» 用 办 公立 具 组 装 星 战 模型 

» 加 综 出 口 铝 笔 检验 监管 

» 中 国 低 碳 产 品 认证 局 动 

» 欧盟 纳米 材料 法 规 的 最 新 进 ... 


图 9-25 “最 新 新 闻 ” 的 效果 


订购 、 结 算 这 样 的 流程 来 实现 
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的 ， 所 以 在 首页 上 制作 产品 的 动态 展示 功能 非常 重要 。 实 例 在 首页 上 设计 了 “推荐 产品 ”、 
“最 新 上 架 ” 以 及 “热门 产品 ”3 个 显示 区 域 ， 下 和 面 束 介绍 产品 展示 区 域 的 实现 方法 。 

CD 对 于 上 述 的 3 个 显示 区 域 ， 在 使 用 程序 开发 之 前 ， 首 先 要 在 Dreamweaver CS 5.5 中 
设计 好 最 终 的 网 页 效果 。 实 例 设计 的 3 个 展示 区 域 如 图 9-26 所 示 ， 每 个 区 域 显 示 最 新 发 布 
的 两 球 产 品 信 息 ， 将 产品 的 图 片 、 价 格 、 数 量 全 部 展示 出 来 ， 并 加 入 “购买 ”和 显示 “ 评 
细 ” 的 按钮 。 




















Tc:\Apache\htdocs\shop\indez. php (XHTML) -0x 





€ font.css top.php left menu.php bottom. php 


| 
guy i ^ 
F Es EAR nn: Bax. 
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[k] Q 100€ v788 x 550» 34 K / 1 秒 简体 中 交 (6B2312) 














图 9-26 设计 产品 展示 的 区 域 效 果 


(2) 3 个 区 域 的 程序 实现 的 方法 是 一 样 的 ， 只 是 按 条 件 碍 询 出 的 数据 结束 不 一 样 。 这 里 
介绍 “推荐 产品 ”区 域 的 代码 实现 方法 如 下 : 





«table widthz" 550" borderz"00" align="center" cellpaddingz" 0" cellspacing="0"> 
<tr> 
<td width="555" height="110"><table width="530" height="110" border="0" align="center" 
cellpadding="0" cellspacing="0"> 
<tr> 
<td width="265"> 
<?php 

$sql=mysql_query("select * from tb_shangpin where tuijian=1 order by addtime desc limit 0,1");//Z 
tuijianz1 的 值 调用 数据 

$info=mysql_fetch_array($sql); 

if($info==false){ 

echo "本 站 暂 无 推荐 商品 !"; 

HM/ 如 果 没 有 数据 ， 则 显示 为 "本 站 和 暂 无 推荐 商品 

else{ 

2» 

«table width2"270" border= "0 cellspacing-" 0" cellpadding="0"> 

















PIT CEMER 





<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if(trim($info[tupian]=="")){ 

echo " 暂 无 图 片 "; © 
MURRA mA MWERA AEA" 
else { 

2» 

«img src=" <?2php echo Sinfo[tupian];?»" widthz"80" height" 80" borderz"0"» 

<?php 
} 

2> 
</div> </td> 
«td width="11" height="16">&nbsp; </td> 
<td width="124"><font color="FF6501"> <img src-"images/circle.gif" widthz" 10" 
heightz"10"» &nbsp;«?php echo $info[mingcheng];?» </font> </td> 
</tr> 
<tr> 
«td height="16">&nbsp; </td> 
«td» «font color="#000000"> 市 场 价 :</font><font color="FF6501"><?php echo $info[shichangjia];?> 
</font> </td> 
</tr> 
<tr> 
«td heightz" 16" » &nbsp;«/td» 
«td» «font color="#000000"> 会 员 价 : </font><font colorZ"FF6501"»«?php echo S$info[huiyuanjia];?» 
</font> </td> 
</tr> 

<tr> 

«td heightz" 16" » &nbsp;«/td» 
«td» «font color='"#000000"> 剩 余数 量 : </font><font color2"13589B"» <?php 

if(Sinfo[shuliang]»O) 

{ 





echo $info[shuliang]; 
j 
else 
{ 
echo "已 售 完 ” 
} 
T> 
</font> </td> 
</tr> 
<tr> 
<td height="30" colspan="2"><a href="lookinfo.php?id=<?php echo $infoļ[id];?>"><img 
src="images/b3.gif" width="34" height="15" border="0"></a> «a href="addgouwuche.php?id=<?php 
echo $info[id];?>"><img src="images/b1.gif" width="50" height="15" border="0"></a> </td> 
</tr> 









L5 
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</table> 
<?php 
} 
je 
</td> 
«td widthz"265"» 
<?php 
$sql=mysql_query("select * from tb_shangpin where tuijian=1 order by addtime desc limit 1,1"); 
$info=mysql_fetch_array($sql); 
if($info==true) 
{ 
2» 
«table widthz"270" border="0" cellspacing-"0" celljpadding= "0 > 
<tr> 
<td width="130" rowspan="5"><div align="center"> 
<?php 
if(trim($info[tupian]=="")){ 
echo "和 暂 无 图 片 "; 
} 
else{ 
2» 
«img src=" «?php echo Sinfo[tupian];?»" width="80" heightz" 80" border="0"> 
<?php 
j 
2» 
</div> </td> 
<td width="11" height="16">&nbsp; </td> 
<td width="124"><font color="FF6501"> <img src-"images/circle.gif" widthz" 10" 
heightz" 10"» &nbsp;«?php echo $info[mingcheng];?» «X/font^ «/td* 
</tr> 
<tr> 
«td heightz"16"» &nbsp;«/td» 
«td» «font color="#000000"> 市 场 价 ;</font><font colorz"FF6501"» «?php echo Sinfo[shichangjia];?» 
</font> </td> 
</tr> 
<tr> 
«td height="16">&nbsp; </td> 
«td» «font color="#000000"> 会 员 价 : </font><font color="FF6501"><?php echo $info[huiyuanjia];?> 
</font> </td> 
</tr> 
<tr> 
«td height="16"> &nbsp;</td> 
«td» «font color="#000000" > 3é| 4x Zt 5g: </font><font color="13589B"> 
<?php 
if($info[shuliang]>0) 





echo Sinfo[shuliang]; 
j 
else 
{ 
echo "CE"; 
} 
?> 
</font> </td> 
</tr> 
<tr> 


<td height="30" | colspanz"2"»«a 


href="lookinfo.php?id=<?php 


【PHP 网 上 购物 系统 前 台 





echo — S$info[id];?» "5 «img 


src-"images/b3.gif" widthz"34" height-"15" border="0"></a> «a href-"addgouwuche.php?id-«?php 
echo Sinfo[1d|;?» "5 «img src-"images/bl.gif" width="50" heightz" 15" borderz"0"» «/a» </td> 


</tr> 
</table> 
<?php 
j 
1S 
</td> 
</tr> 
</table> </td> 
</tr> 
<tr> 


«td height="10" background-z"images/linel.gif"» </td> 


</tr> 
</table> 


(3) 按 上 述 的 程序 实现 方法 ， 


果 如 图 9-27 所 示 。 


推荐 产品 : 


» 飞利浦 CORD 280 


A 市 场 价 : 145 
j x 会 员 价 : 100 
AA 剩余 数量 : 10 


[LEER | [>| 购 关 | 


» 兄弟 标签 打印 机 色 带 
市 场 价 : 155 
会 员 价 : 105 
剩余 数量 10 
[SA | |» | 3c 





热门 产品 : 


» 兄弟 标签 打印 机 色 带 
市 场 价 : 155 
会 员 价 : 105 


剩余 数量 : 10 








Tad 


[ER ) [» | 购买 ] 











将 万 外 两 个 产品 展示 的 功能 设计 完成 ， 最 后 可 以 实现 的 效 


更 多 . . 


» 办 公 桌 -01 
市 场 价 : 1200 
会 员 价 : 1000 
剩余 数量 : 10 
PER] 


[ES ] | | nc 


» 飞利浦 CORD 280 

市 场 价 : 145 

会 员 价 : 100 

剩余 数量 : 10 
Dn | |x| f 3c | 


» IAA- 
市 场 价 : 1200 
mýt: 1000 
剩余 数量 10 
EZALE 








图 9-27 首页 的 商品 展示 效果 
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Joo 底部 版 权 页 面 ) 


底部 版 权 页 面 是 一 个 静态 的 页 面 ， 制 作 非 音 简 单 。 在 Dreamweaver CS 5.5 中 进行 直接 排 
版 设计 即 可 ， 完 成 的 效果 如 图 9-28 PZR. 


HE] C: whpachevhtdocsvshopAbottom. php (XHTXL) -0X 











OR 
IMMSAASSASSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSSASSSSSASASARASSSSSSSSSSSSSASASSSSSSSSSASSASSSSSSSSSSSSSSSSSSASSSSSSSASSSS SS 








(R| Q hoos [778 x 165v 1 K / 1 $5 fé febr (682312) 








图 9-28 版 权 页 面 的 设计 效 末 


以 上 网 站 的 首页 制作 全 部 结束 ， 如 宋 需 要 快速 建立 首页 ， 可 以 直接 参考 光盘 中 完成 的 页 
面 ， 碍 看 代码 ， 可 以 方便 地 完成 网 上 购物 系统 首页 的 设计 与 制作 。 














SUL ”会员 系 统 功能 














网 站 的 会 员 系 统 的 首页 可 以 让 用 户 完成 登录 或 注册 。 当 输入 用 户 名 和 密码 后 ， 单 击 “ 提 
六 ”按钮 ， 即 转 到 chkuser.php 页 和 面 进行 判断 是 否 成 功 登 录 。 当 单 击 “注册 ”文学 链接 时 ， 
将 会 打开 网 站 的 会 员 注 册页 面 agreereg.php 进行 注册 。 单 击 “ 找 回 密码 ”会 弹出 找 回 密码 的 
Windows 对 话 窗口 。 下 向 束 介 绍 会 员 系 统 的 开 友 方法 。 


SERLO 会 员 登 录 判 断 























会 员 在 首页 输入 用 户 名 和 密码 后 ， 单 击 “ 提 交 ” 按 钮 ， 只 有 用 户 名 、 密 码 、 验 证 码 全 部 
正确 才 可 以 登录 成 功 ， 如 末 发 生 错 误 就 需要 显示 相关 的 错误 信息 ， 所 有 的 功能 都 要 用 PHP 
进行 分 析 判 新。 创建 一 个 空白 PHP 页 面 ， 并 命名 为 chkuserphp。 

在 该 页 面 中 加 入 如 下 的 代码 : 


<?php 

include("conn/conn.php");// 调 用 数据 库 连接 

$username=$ POST[username]; 

$userpwd=md5($_ POST[userpwd]); 

$yz-$ POSTIyz]; 

$num-$ POST[num]; 

if(strval($yz)!2strval($num))( 
echo "«script^alert( WUEMA £8 TX V); history.go(- 1); /script? "; 
exit; 


MUREDE R, Mhen “WUEMA ENR!” . JP BOR IRIS DII 




















PIT CEMER 








class chkinput{ 
var $name; 
var $pwd; 
function chkinput($x,$y){ ! 
$this->name=$x; > 
$this->pwd=$y; r 
j 
function checkinput()( 
include("conn/conn.php"); 
$sql2mysql query("select * from tb user where namez"" Sthis-» name." "",$conn); 
$info2mysql fetch, array($Ssql); 
if(Sinfo--false)( 
echo "<script language='javascript'>alert( 不 存在 些 用户 ! ";history.back();«/script^ "; 
exit; 
/如果 数据 库 里 不 存在 该 用 户 名 ， 则 显示 “不 存在 此 用 户 ”， 并 返回 
else{ 
if(Sinfo[dongjie]--1)( 
echo "<script language='javascript'>alert( 该 用户 已 经 被 冻结 ! ";history.back(); 











</script>"; 
exit; 
VH P Beeren fS, Mwea ZHP CARA! ”， 并 返回 
if($info[pwd]==$this->pwd) 
{ 
session start(); 
$ SESSION([username ]-S$info[name]; 
session register("producelist"); 
$producelist=""; 
session_register("quatity"); 
$quatity=""; 
header("location:index.php"); 
exit; 
j 


else ( 


echo "<script language- javascript» alert( IHA £8 V !. ;history.back(); «/script^ "; 
exit; 


M/ 如 果 用 户 密 人 码 错误 ， 则 显示 “密码 输入 错误 ! ”， 并 返回 





$obj=new chkinput(trim($username),trim($userpwd)); 
$obj-»checkinput(); 
7» 








该 段 程序 ， 首 先 判断 验证 码 、 用 户 名 以 及 密码 是 否 是 正确 的 代码 ， 如 果 不 正 确 ， 则 显示 
相应 的 错误 信息 ， 如 果 全 部 正确 ， 则 登录 成 功 并 返回 登录 的 首页 。 















TT 


SUUM 会 员 注 册 功 能 








会 员 注 册 功 能 并 不 只 是 简单 的 一 个 网 页 束 能 实现 ， 它 需要 同意 协议 以 及 判断 用 户 是 人 否 已 
存在 ， 写 入 数据 等 细 蔬 步骤 如 下 。 

d) 早 击 “注册 ”文字 链接 时 ， 将 会 打开 网 站 的 会 员 注 册页 面 agreereg.php， 该 页面 制 
作 的 效果 如 图 9-29 所 示 。 访 页 面 的 内 容 是 必 不 可 少 的 ， 提 示 给 网 站 管理 员 ， 为 避免 日 后 与 
注册 用 户 发 生 纠 纷 ， 需 要 提前 将 网 站 所 提供 的 具体 服务 和 约束 等 内 容 ， 放 到 注册 信息 里 面 ， 
这 样 可 以 有 效 地 保护 目 己 的 利益 


TC: hlpackeVhidocslrhestagraerag. pho (EHTKEI = 





A iepbp leli mi lp em, php 





| ow UI TENER | NP. | NIFA | FROR | 用 户 中 心 [TAGEN | I i 39 ji 


L 司 | — — €—ÁP Pu(——Àa —— € NI 7709 
green 下 和 
TE P mem 

TEREA: 3 pes : i Roron e T RHET Erg dE a EENES: 

i | d enn "T : i Sie. EB As pia HEEE ame ne 

Is umm — NM an Ha Arr S 站 BHE, TE 2 

War : nd 

gue MEME 

(tt 

ee 


中 





9-29 同意 网 站 里 的 服务 条 于 


(2) 单 击 “同意 ”按钮 后 ， 束 打开 具体 的 注册 用 户 信 息 填 写 内 容 页 。 该 页 面 制作 也 比较 
人 简单， 只 需要 以 数据 库 中 tb user 数据 表 的 字段 名 为 准 ， 在 注册 页 面 分 别 创 建 相应 的 文本 框 
即 可 ， 如 图 9-30 所 示 。 





T DCApackeVhtdoeslrhes se: pha (TETMLI -08 
ca bep.php leli mana php bolies. php 





——————m———————————————————————————— E 


banns AR E- a 


d VN EAE ISTE | # Ara | PB lom LO ads | mess i gi 3a 





314 E2EALAFAEALALAEAREEILIEEEAILIEILILAET L-] 
-eari ma ea TT Mibtigenz? 0 


图 9-30 ”用户 填写 注册 信息 的 页 面 





G) 其 中 的 技术 难点 在 于 “得 看 昵称 是 售 已 用 ”功能 ， 在 输入 用 户 昵 称 时 ， 需 要 单 击 该 
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按钮 ， 检 查 数 据 库 中 是 侍 已 存在 该 用 户 上 昵称 。 实 现 的 方法 代码 如 下 : 


<script language="JavasCript"> 
function chknc(nc) C 
| © 
windows.open("chkusernc.php?nc="+nc,"newframe","width=200,height=10,left=500,top=200,menubar= 这 
no,toolbar-no,location-no,scrollbars-no,location2no"); 
}/ 单 独 打 开 Windows 窗口 通过 调用 chkusernc.php 页 面 进行 判断 
</script> 


Br EHRCESRS SE ERAI N MÆ chkusernc.php, i LIBI a F : 


<?php 
$nc-trim($ GET[nc]); 
2» 
<?php 
include("conn/conn.php"); 
2> 
<html> 
<head> 
<title> 
昵称 重用 检测 
</title> 
<link rel="stylesheet" type="text/css" href="css/font.css"> 
</head> 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<table width="200" height="100" border="0" align="center" cellpadding="0" cellspacing="0" 
bgcolor="#eeeeee"> 
<tr> 
«td height="50"><div align="center"> 
<?php 
if($nc=="" 
{ 
echo "iei NETT; 
j 


else 


{ 


$sql=mysql_query("select * from tb user where name='".$nc. 


"ttt 


,Sconn); 
$info2mysgl fetch, array($sql); 

if($info—-true) 

{ 

echo "对 不 起 ,该 上 昵称 已 被 上 占用; 

} 

else 

{ 

echo "恭喜 ,该 昵称 没 被 占用 局 ; 
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j 
2» 
</div> </td> 
</tr> 
<tr> 
<td height="50"><div align="center"><input type="button" value=" fff 4E " class="buttoncss" 
onClick="window.close()"></div> </td> 


</tr> 
</table> 
</body> 
(4) 在 单 击 “提交 ”按钮 时 ， 还 要 实现 所 有 的 字段 检查 功能 ， 调 用 JavaScript 程序 进行 
检查 的 代码 如 下 : 


<script languagez" JavaScript"? 
function chkinput(form) 


{ 


if(form.usernc.value== 


{ 
alert(" 请 输入 昵称 !"); 
form.usernc.select(); 


"tt 


return(false); 

} 

if(form.p1.value=="") 

{ 
alert(" 请 输入 注册 密码 !"); 
form.pl.select(); 
return(false); 


j 


if(form.p2.value--"") 

{ 
alert(" 请 输入 人 确认 密码 !"); 
form.p2.select(); 
return(false); 


j 
if(form.pl.value.length«6) 


{ 

alert( "E HRB 1 BE NV XT. 6!"); 
form.pl.select(); 

return(false); 


j 


if(form.pl.value!-form.p2.value) 


{ 
alert(" 密 人 与 重复 密码 不 同 !"); 


form.pl.select(); 





return(false); 


} 
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"n 


if(form.email.value-- 
{ 
alert(" 请 输入 电子 邮箱 地 址 1"); 
form.email.select(); 
return(false); 


} 
if(form.email.value.indexOf( @')<0) 


{ 
alert(" 请 输入 正确 的 电子 邮箱 地 址 1"); 


form.email.select(); 





return(false); 
j 


if(form.tel.value-- 


{ 
alert(" 请 输入 联系 电话 !"); 


form.tel.select(); 


ntt 


return(false); 


j 


if(form.truename.value-z"") 
{ 
alert(" 请 输入 真实 姓名 !"); 
form.truename.select(); 
return(false); 


j 


if(form.sfzh.value-z"") 
{ 
alert(" 请 输入 身份 证 号 !"); 
form.sfzh.select(); 
return(false); 
} 
if(form.dizhi.value=="") 
{ 
alert( 2i 46i A Z& RE FEE!) 
form.dizhi.select(); 
return(false); 
j 
if(form.tsda.value-- 
{ 
alert(" 请 输 密 码 提示 答案 !"); 
form.tsda.select(); 


"tt 


return(false); 


} 
if((form.tsl.value==1)&&(form.ts2.value=="")) 

{ 

alert(" 请 选择 或 输入 密码 提示 答案 !"); 


form.ts2.select(); 
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return(false); 


j 


return(true); 


j 


</script> 


该 段 程序 是 验证 表 蛙 时 经 党 使 用 的 方法 ， 读 者 可 以 重点 浏览 并 掌握 其 功能 ， 在 其 他 系统 
的 开发 中 也 经 营 补 使 用 到 。 

(50 在 验证 表单 没 问 题 后 ， 才 将 衣 单 的 数据 传递 到 savereg.php 负面 进行 数据 表 的 插入 
记录 操作 ， 也 就 是 实质 上 的 保存 用 户 注 册 信息 的 操作 。 其 体 的 代码 如 下 : 


<?php 
session start(); 























include("conn/conn.php"); 
$name-$ POST[usernc]; 
$pwdl-$ POST[pl]; 
$pwd2md5($ POST[p1]); 
$email=$ POST[email]; 
$truename-$ POST[truename]; 
$sfzh-$  POST[sfzh]; 

$tel-$ POST[tel]; 
$qq=$_POST[qq]; 

if($ POSTI[ts1]==1) 


{ 
$tishi=$_ POSTIts2]; 
} 
else 
{ 
$tshi-$ POSTI[ts1]; 
} 


$huida=$ POSTI[tsdal: 
$dizhi=$_POST[dizhi]; 
$youbian=$_POST[yb]; 
$regtime-date(" Y -m-j"); 
$dongjie-0; 


111 min 


$sql=mysql_query("select * from tb user where name-"".$name.""",$conn); 
$info2mysql fetch, array(Ssql); 
if(Sinfo--true) 
{ 
echo "<script>alert( ZUG Ff CATE V);history.back(); «/script^ "; 
exit; 
j 


else 


{ 


mysql_query("insert into tb_user (name,pwd,dongjie,email,truename,sfzh,tel,qq,tishi,huida, 





dizhi,youbian,regtime,pwd1) values ('$name','$pwd','$dongjie','$email','’$truename','$sfzh','$tel', 
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'$gqgq','$tishi','$huida','$dizhi','$youbian','$regtime','$pwd1")",$conn);// 按 字段 对 应 相应 的 数据 
session register("username"); 
$username=$name: 
session register("producelist"); 全 


"tt, 


$producelist-""; 
session register("quatity"); 


$quatityz""; 
echo "&script^alertZ&2£, 3370] 9]! );window.location-'index.php'; «/script? "; 


HM/ 插入 数据 后 显示 注册 成 功 ， 并 返回 首页 index.php 
2» 
通过 以 上 几 个 步骤 的 程序 编写 才能 完成 一 个 会 员 注 册 的 功能 ， 
的 一 个 逻辑 实现 过 程 。 


找 回 密码 功能 P 


会 员 在 使 用 过 程 中 起 记 和 密码 也 是 经 常 过 到 的 事情 ， 在 实例 中 单 击 “ 找 回 密码 ”文子 链 


接 ， 将 打开 相应 的 窗口 实现 找 回 密码 的 功能 ， 其 体 的 实现 步 缀 如 下 。 
(1) 在 制作 的 left menu.php 页 面 中 加 入 JavaScript 的 验证 代码 ， 实 现 的 功能 是 单 击 “ 找 


加 密码 ”链接 时 ， 打 开 openfindpwd.php 页 面 进行 验证 ， 代 人 码 如 下 : 


"tt, 














般 的 会 员 注 册 都 是 这 样 

















<script language="javascript"> 


function openfindpwd(){ 
windows.open("openfindpwd.php","newframe","left2200,top-200,widthz200,height-100,menubarzno, 


toolbar-no,location-no,scrollbars-no,location2no"); 


j 


</script> 


(2) 使 用 Dreamweaver 设计 出 找 回 密码 的 页 面 如 图 9-31 所 示 ， 只 需要 一 个 简单 的 对 话 
窗口 ， 输 入 昵称 并 进行 判断 即 可 。 


了 :ADachehtdcoeswshonwonentindnwda php -Dxx 








[&]éy Q 00$ [370 x Bv 3 K / 





图 9-31 找 回 密码 的 页 面 


(3) 在 输入 需要 找 回 密码 的 昵称 之 后 ， 单 击 “ 确 定 ”按钮 需要 进行 表单 验证 ， 判 断 是 否 
为 室 ， 如 果 不 为 空 则 指向 findpwd.php 页 面 显示 “密码 提示 ” 输入 提示 的 答案 ， 如 图 9-32 


ZR o 
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<script language-"javascript"? 
function chkinput(form) 
{ 


if(form.nc.value=="") 


{ 
alert(" 请 输入 您 的 昵称 !"); 
form.nc.select(); 


return(false); 


j 


return(true); 


j 


X/script 


T C: M pachekht does shopkfindpwi. php EXE 


7.7". r.31 r.341 rm. TT FE. rS rm. n. nin rm. mu nua rm. 


hd 
[k]é9y Q 00$ vr x 131v 4 1 








图 9-32 ”密码 提示 页 面 


(4) 输入 “ 拓 示 管 采 ”之 后 ， 青 早 击 “确定 ”按钮 ， 也 要 进行 表 蛙 验证 ， 并 转 癌 最终 显 


a ABB UB showpwd.php， 验 证 的 代 公 如下: 


<script language="javascript"> 
function chkinput(form) 
{ 
if(form.da.value=="") 
{ 
alert( iei 48 AN ABERA RN; 
form.da.select(); 
return(false); 
j 
return(true); 


j 


</script> 


<form name="form2" method="post" action="showpwd.php" onSubmit="return chkinput(this)"> 





(5) showpwd.php 的 页 面 比 较 简 单 ， 只 需要 答 询 数据 库 ， 把 符合 条 件 的 数据 显示 出 来 ， 








即 把 昵称 和 密码 显示 在 页 面 上 即 可 ， 如 图 9-33 所 示 。 
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CApache ht does shonp'showpwd. php - Dx 


font. css conn. php 








9-33 最终 的 显示 密码 页 面 


Section 





新 闻 公 告 系 统 








网 站 的 “新 闻 公 告 ” 在 首页 及 各 个 页 面 显 示 标 题 ， 当 单 击 相应 的 标题 时 ， 打 开 详细 的 显 








示 内 容 页 面 gonggao.php。 与 网 站 的 新 闻 信 息 相关 的 页 面 ， 一 共有 2 个 ，gonggao.php HT Si 
示 具 体 的 信息 内 容 ， 另 一 个 是 用 于 单 击 首页 的 “更 多 >>” 文 字 链 按时， 打开 所 有 的 信息 标题 


页 面 的 gonggaolist.php. 


ss AARE 页 列表 


所 有 的 信息 标题 页 面 gonggaolist.php 制作 的 效果 如 图 9-34 所 示 。 


四 C:\Apache\htdocs\shop\EongEaolist. php (XHTML) 





. iara 
Se "— -———— ds 


3. .提交 注册 = É 





818 x 512v 17 K / 1 秒 简体 中 文 (582312) 





图 9-34 所 有 信息 标题 页 面 效 果 











L5 


PHP+My 









该 页 面 的 编号 程序 部 分 如 下 所 示 : 


<?php 
$sql=mysql_query("select count(*) as total from tb_gonggao",$conn); 
$info2mysql fetch, array(Ssql); 
$total-Sinfo[total]; 
if($total--0) 
{ 
echo "本 站 暂 无 公告 !"; 
HM/ 调 用 tb gonggao 数据 ， 如 果 没 有 则 显示 “本 站 和 暂 无 公告 !” 
else 
{ 
?> 
<table width="530" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr bgcolor="#EEEEEE"> 
<td width="296" height="20"><div align="center"> y 4 </div></td> 
<td width="136"><div align="center"> /z 4h] [8] </div></td> 
«td width="68"><div align="center"> Æ VJ &</div> </td> 
</tr> 
<?php 
$pagesize=20; 
if ($total<=$pagesize){ 
$pagecount=1; 
j 
if(($total% $pagesize)!=0){ 
$pagecount=intval($total/$pagesize)+1; 


Jelse( 
$pagecount-$total/Spagesize; 


} 
if(($_GET[page])==""){ 
$page=1; 
else { 
$page-intval($ GET[page]); 
j 


$sgll-mysql query("select * from tb gonggao order by time desc limit ".($page- 


I)*$pagesize.",Spagesize ",Sconn); 
while(Sinfol-mysql fetch array($sql1)) 
{ 
?> 
<tr> 
«td height="20"><div align="left">-<?php echo Sinfol[title];2» </div></td> 
«td height="20"><div align="center"> «?php echo $info1[time];?></div></td> 
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«td height-"20"*» «div alignz2"center'^«a href-"gonggao.php?id-«?php echo 
$infol[id]:?>"> 查 看 </a></div></td> 
</tr> 


| <?php - | 


2» 
<tr> 
<td height="20" colspan="3"> &nbsp; 
<div align="right"> 本 站 共有 公告 &nbsp: 
<?php 
echo $total; 
2» 
&nbsp; 4& &nbsp; $ H i zs &nbsp;«?php echo $pagesize;?»&nbsp; 条 &nbsp; 第 &nbsp;«?php echo 
$page;?»&nbsp; J1/J.: &nbsp;«?php echo $pagecount; ?» &nbsp; 页 
<?php 
if($page>=2) 
{ 
2» 

«a hrefz"gonggaolist.php?page-1" title" Pi W "><font face-"webdings"» 9 «/font»«/a» «a 
href-"gonggaolist.php?id-«?php echo $id;?» &amp;page-«?php echo $page-1;?»" title=" 亲 一 页 "><font 
facez"webdings"^ 7 </font></a> 

<?php 

j 
if($pagecount«-4)( 
for($i=1;$i<=$pagecount;$i++){ 
Is 
<a href=" gonggaolist.php?page=<?php echo $i;?>"><?php echo $i;?></a> 
<?php 
j 
}else{ 
for($i=1;$i<=4;$i++){ 
> 

«a href="gonggaolist.php?page=<?php echo $1;?» "5 «?php echo $1;?» «/a» 

<?php }?> 

«a href="gonggaolist.php?page=<?php echo $page-1;?>" title=" 后 一 页 "><font 
face="webdings"> 8 </font></a> «a href="gonggaolist.php?id=<?php echo $id;?>&amp;page=<?php 
echo $pagecount;?»" title=" }€ W "><font face="webdings"> : </font> </a> 

<?php }?> 

</div></td> 
</tr> 
</table> 
<?php 
j 


2» «/td» 
</tr> 
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</table> 


该 页 面 的 技术 难点 在 于 新 闻 标 题 的 分 页 显示 功能 ， 在 显示 的 标题 太 多 时 ， 一 般 部 要 使 用 
上 述 的 分 页 显示 功能 ， 实 现 按 页 显示 记录 。 


:SR 显示 详细 内 容 


具体 信息 量 显 示 页 面 ， 通 常 包 括 显 示 所 要 显示 信息 的 标题 、 时 则 以 及 出 处 ， 制 作 的 具体 
效果 如 图 9-35 所 示 。 


bc C:XApachehhtdocskshopigonggao. php (XHTML) - 口 X 



































CRED top.php left menu php function.php bottom. php 


~ 
a 


~% 
^ 
SINT 
~ 
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:| 一 | 提交 | 注册 RATE > 
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Y E N 
MEE 
E: 


Po 





[km Q 100% v788 x 395v 15 K / 1 b. 简体 中 站 (GB2312) 














图 9-35 详细 新 闻 页 面 


该 页 面 的 编写 程序 部 分 如 下 所 示 : 


«table width2"530" border="0" align="center" cellpaddingz"0" cellspacing="1"> 
<?php 
$id-$ GET[id]; 
$sgl2mysql query("'select * from tb gonggao where id='".$id."",$conn); 
$info2mysgql fetch, array($sql); 
include("function.php"); 
lo 
<tr> 
«td width="24" height="25" bgcolor="#FFFFFF"> <div align="center"> </div> </td> 
<td width="315" bgcolor="#FFFFFF"><div align="center"> 公 f$; È  : <?php echo 
unhtml(Sinfo[title]);?» </div></td> 
«td width="66" bgcolor="#FFFFFF"><div align="center"> /z pl] [H]: </div></td> 
«td width="120" bgcolor="#FFFFFF"> «div align="left"><?php echo $info[time];?> </div></td> 
</tr> 
<tr> 
<td height="125" bgcolor="#FFFFFF"> <div align="center"></div></td> 
<td height="125" colspan="3" bgcolor="#FFFFFF"> <div align="left"> <?php echo 
unhtml(Sinfo[content]);?» </div></td> 
</tr> 
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</table> 
通过 上 述 两 个 页 面 的 设计 ， 新 闻 公 告 系统 的 前 人 台 部 分 即 开 发 完成 。 








Eee 产品 的 订购 功能 


购物 车 系统 主要 由 网 上 产品 订购 与 后 台 结 算 这 两 个 功能 组 成 ， 实 例 中 与 购物 车 相关 的 产 
品 显 示 的 页 面 就 包括 一 个 “购买 ”的 功能 按钮 。 其 中 主要 包括 index.php、 用 于 显示 产品 详细 
信息 的 页 面 lookinfo.php,“ 最 新 上 架 ” 频 道 页 面 Shownewprphp,“ 推 荐 产品 ”频道 页 面 
showtujjian.php,“ 热 门 产 品 ” 频 道 页 面 showhot.php,“ 产 品 分 类 ”频道 页 面 showfenlei.php、 
人 1 而 实现 的 功能 。 


9.6. 


产品 介绍 页 面 lookinfo.php 是 用 来 显示 商品 细节 的 页 面 。 细 节 页 面 要 能 显示 商品 所 有 的 
详细 信息 ， 包 括 丙 品 价 格 、 商 品 产地 、 商 品 单位 及 商品 向 片 等 ， 同 时 要 显示 是 售 还 有 剩余 产 
品 以 及 放 入 购物 车 等 功能 ， 实 例 还 加 入 了 “商品 评价 ” 

(OD 由 所 需要 建立 的 功能 出 发 ， 可 以 建立 如 图 9-36 所 示 的 动态 页 面 。 在 页 面 中 ，PHP 
代码 岁 标 代表 加 入 动态 命令 实现 该 功能 。 


5 C: hpachevht docsvshopvlookinfo. php (XHTML) - 口 X 






































€» top.php  conn.php left menu. php bottom. php 








(20 该 模块 的 程序 分 析 如 下 ， 其 中 对 购物 车 的 订购 代码 进行 了 加 粗 说 明 : 


<?php 
$sql=mysql_query("select * from tb_shangpin where id=".$_GET[id]."",$conn); 





D 
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$info=mysql_fetch_object($sql); 
2> 
<tr> 
<td width="89" height="80" rowspan="4" align="center" valign="middle" bgcolor="#FFFFFF"> <div 
align="center"> 
<?php 
if($info->tupian==""){ 
echo "和 暂 无 图 片 "; 
} 
else 
{ 
I> 
<a href="<?php echo $info->tupian;?>" target="_blank"><img src="<?php echo $info->tupian;?>" 
at=" £r Zr X Kl" width="80" height="80" border="0"></a> 


<?php 
j 
2» 
</div> </td> 
<td width="92" height-"20" align="left" bgcolor="#FFFFFF"><div align="center"> 丙 品 名 称 : 
</div></td> 


<td width= 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
»mingcheng;?* «/div? </td> 

«td width" 100" bgcolor="#FFFFFF"><div align="center"> 入 市 时 间 : </div></td> 

«td widthz" 129" bgcolor= *FFFFFF"*» «div alignz"left"» &nbsp;«?php echo $info- 
>addtime;?></div> </td> 

</tr> 

<tr> 

«td height="20" align="left" bgcolor="#FFFFFF"><div align="center"> 会 员 价 : </div></td> 

«td widthz" 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
>huiyuanjia;?> </div> </td> 

«td width="100" bgcolor="#FFFFFF"><div align="center"> TH: </div></td> 

«td width= 129" bgcolor= *FFFFFF"*» «div alignz"left"» &nbsp;«?php echo $info- 
»shichangjia;?» </div></td> 

</tr> 

<tr> 

«td height="20" align="left" bgcolor="#FFFFFF"><div align="center"> 等 级 : </div></td> 

«td widthz" 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
»dengji;?» </div> </td> 

«td width="100" bgcolor="#FFFFFF"><div align="center"> 品 牌 : </div></td> 

<td Width= 129" bsgcolor= *FFFFFF"* «div align-z"left"» &nbsp;«?php echo $info- 
»pinpai;?» </div></td> 

</tr> 

<tr> 

«td height="20" align="left" bgcolor="#FFFFFF"><div align2"center" 5713575; </div></td> 

«td widthz" 134" bgcolor= *FFFFFF"» «div alignz"left"» &nbsp;«?php echo $info- 
»xinghao;?*» «/div* </td> 
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«td width="100" bgcolor="#FFFFFF"><div align="center"> 数 量 : </div></td> 

«td width-" 129" bsgcolor= *FFFFFF"'* «div align="left"> &nbsp;«?php echo $info- 
>shuliang;?></div> </td> 

</tr> - 
<tr> ©) 
<td width="89" height="69" bgcolor="#FFFFFF"><div align="center"> H m faj: </div></td> 

«td height="69" colspan="4" bgcolor="#FFFFFF" valign="top"> «div align="left"><br> 
&nbsp;&nbsp;&nbsp;&nbsp;<?php echo $info->jianjie;?> </div></td> 

</tr> 

</table> </td> 

</tr> 

</table> 

<table width="530" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 

<tr> 

«td» «div align="right"><a href="addgouwuche.php?id=<?php echo $info->id;?>"> 放 入 购物 车 </a> 
&znbsp;&nbsp;</div></td>1/ 单 击 “ 放 入 购物 车 ”传递 产品 的 Id 号 并 到 addgouwuche.php 去 结算 

</tr> 


</table> 
<?php 
if($_SESSION[username]!="") 
{ 
2» 
<form  name-"forml" method="post" action-"savepj.php?id-«?php ^ echo $info->id;?>" 


onSubmit-"return chkinput(this)"? 
«table widthz"530" borderz"0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
«td height="25" bgcolor="#EEEEEE"> <div align="center" style="color: #FFFFFF"> 
<div align="left"> &nbsp;&nbsp;«span style="color: #000000"> 发 表 评 论 </span></div> 
</div> </td> 
</tr> 
<tr> 
<td height="150" bgcolor="#999999"><table width="530" border="0" align="center" 
cellpadding="0" cellspacing="1"> 
<script language="javascript"> 
function chkinput(form) 


if(form.title.value=="") 
{ 
alert(" 请 输入 评论 主题 !"); 
form.title.select(); 
return(false); 
j 
if(form.content. value-- 
{ 
alert(" 请 输入 评论 内 容 !"); 
form.content.select(); 


"tt 









PHP+ 


return(false); 


j 


return(true); 


</script> 
<tr> 

<td width="80" height="25" bgcolor="#FFFFFF"><div align="center"> YE ie 3i: </div></td> 
<td width="467" bgcolor="#FFFFFF"> <div align="left"> 
<input type="text" name="title" size="30" class="inputcss" style="background-color:#e8f4ff 
onMouseOver="this.style.backgroundColor='#ffffff" 
onMouseOut="this.style.backgroundColor='#e8f4ff "> 
</div></td> 
</tr> 
<tr> 
«td height="125" bgcolor="#FFFFFF"><div align="center"> Eie AZ: </div></td> 
«td height="125" bgcolor="#FFFFFF"> <div align="left"> 
<textarea name="content" cols="70" rows="10" class="inputcss" style="background-color:#e8f4ff " 
onMouseOver="this.style.backgroundColor='#ffffff" 
onMouseOut="this.style.backgroundColor='#e8f4ff "> </textarea> 
</div></td> 
</tr> 
</table></td> 

</tr> 
</table> 

<table width="530" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 

<tr> 


" 


<td><div align="center"> 

<input name="submit2" type="submit" class="buttoncss" value=" RK "> 

&nbsp;&nbsp;&nbsp;<a href="showpl.php?id=<?php echo $ GET[id]?»"» 查看 该 商品 评论 
</a> </div></td> 

</tr> 

</table> 

</form> 

<?php 

} 


?> 





(3) 在 上 面 的 代码 中 ， 产 品 的 展示 只 是 数据 的 查询 及 显示 的 功能 ， 核 心 在 于 “发 表 评 
论 ” 在 单 击 “ 发 表 ” 按 钮 时 是 传递 到 savepj.php 页 面 保存 评价 的 ， 其 页 面 的 代码 如 下 : 











<?php 
include("conn/conn.php"); 
$title-$ POST[title]; 
$content-$ POST [content]; 
$spid-$ GET[id]; 
$time-date(" Y -m-j"); 
session start(); 
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min 


$sql=mysql_query("select * from tb user where name-2".$ SESSION[username].""",Sconn); 
$info2mysql fetch array($sql); 

Suserid-Sinfo[id]; 

mysql query("insert into tb pingjia (userid,spid,title,content,time) values 
('Suserid', Sspid','Stitle','Scontent','Stime") ",Sconn); >D 


echo "<script>alert(" 评 论 发 表 成 功 !);history.backOj;</script>"; 





?> 


最 新 上 架 频 道 


单 击 导 航 条 中 的 “最 新 上 架 ” 链 接 到 页 面 Shownewprphp， 访 页 面 主要 是 显示 数据 库 中 
最 新 上 架 的 商品 。 
CD 首先 ， 完 成 静态 页 面 的 设计 ， 访 页 面 完 成 后 的 效果 如 图 9737 PTR. 


C: A pacheXhtdocsVshopishownewpr. php (XHTML) -Bx 











HIRED top.php left menu.php bottom. php 





100% ”v788 x 391v 18 K / 1 $6 简体 中 交 (GB2312) - 


图 9-37 最 刹 上 染 的 静态 页 面 效 果 
(20 代码 主要 核心 部 分 如 下 所 未: 


«table width="550" height="70" borderz"0" align="center" cellpadding-"0" cellspacingz"0"» 
<?php 
$sql=mysql_query("select * from tb_shangpin order by addtime desc limit 0,4",$conn); 
/从 产品 表 中 调 出 最 新 加 入 的 4 条 产品 信息 
$info=mysql_fetch_array($sql); 
if($info==false){ 
echo "本 站 和 暂 无 最 新 产品 !"; 
} 
else{ 
do{ 
2> 
<tr> 
«td width="89"rowspan="6"><div align="center"> 
<?php 









* 
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if(Sinfo[tupian]22" )( 
echo " 暂 无 图 片 !"; 
} 
else{ 
fo: 
«a  href-"lookinfo.php?id-«?php echo $infoļid];?>"><img border="0" | src-"«?php echo 
$info[tupian];?»" width" 80" height="80"></a> 
<?php 
} 
le: 
</div></td> 
«td width="93" height="20"><div align="center" style="color: #000000"> 疝 品名 称 : </div></td> 
<td colspanz"5"» «div align="left"><a href="lookinfo.php?id=<?php echo $info[id]:?>"><?php echo 
$info[mingcheng];?» «/a» </div></td> 
</tr> 
«tr? 
«td width="93" height-"20"» «div align="center" style="color: 4000000" » rj i: </div></td> 
«td widthz2" 101" height-"20"*» «div alignz"left"» «?php echo S$info[pinpai];?» «/div5 </td> 
«td widthz"62"» «div align="center" style="color: 4000000" » rj mA! y: </div></td> 
«td colspanz"3"* «div alignz"left"» «?php echo S$info[xinghao];?» «/div» </td> 
</tr> 
<tr> 
«td width="93" height="20"><div align="center" style="color: #000000"> 商 品 人 简介 : </div></td> 
«td height="20" colspan="5"><div align="left"><?php echo $infoļ[jianjie];?> </div></td> 
</tr> 
<tr> 
«td height="20"><div align="center" style="color: 4000000"» ET H #H: </div></td> 
«td height="20"><div align="left"><?php echo $infoļaddtime];?></div> </td> 
«td height="20"><div align="center" style="color: #000000"> 剩 余数 量 : </div></td> 
«td width="69" height="20"><div align="left"><?php echo $info[shuliang];?> </div></td> 
<td width="63"><div align="center" style="color: #000000"> 了 商品 等 级 : </div></td> 
«td width="73"><div align="left"><?php echo $info[dengji];?> </div> </td> 
</tr> 
<tr> 
«td height="20"><div align="center" style="color: 4000000" » RM: </div></td> 
«td height="20"><div align="left"><?php echo $info[shichangjia];?> 元 </div> </td> 
«td height="20"><div align="center" style="color: 4000000" n: </div></td> 
«td height="20"><div align="left"><?php echo $info[huiyuanjia];?> 7G €/div? </td> 
«td height="20"><div align="center" style="color: #000000"> 折 扣 : </div></td> 
<td height="20"><div align="left"><?php echo (@ceil(($info[huiyuanjia]/$info[shichangjia])*100)). 
"%";?></div></td> 
</tr> 
<tr> 
<td height="20" colspan="6" width="461"><div align="center"> &nbsp;&nbsp;&nbsp;&nbsp;«a 
href="addgouwuche.php?id=<?php echo $infoļ[id];?>"><img src="images/b1.gif" width="50" 
height="15" border="0" style=" cursor:hand"></a></div> </td> 
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</tr> 
<tr> 
«td height=" 10" colspan="7" background="1mages/linel.g1f"></td> 
</tr> 
<?php 
)while(Sinfo2mysql fetch array(S$sql)); 
j 
2 
</table> 


9.6.3 Hn 1B 











产品 ”链接 到 页 面 showtujjian.php， 访 页面 主要 是 显示 数据 库 中 
推荐 的 商品 。 
(D 首先 ， 完 成 静态 页 面 的 设计 ， 该 页面 完成 后 的 效果 如 图 9-38 所 示 。 


E] C: \Apachethtdocs\shop\showtui jian. php (XHTML) - 口 X 


HIRED top. php left menu.php bottom. php m 
^ 


搜索 | uem 





TS Q 1008  . T88 x 391v 20 /1 秒 简体 中 交 (6B2312) — 


图 9-38 ”推荐 产品 的 静态 页 面 效果 
(20 推荐 产品 的 功能 和 最 刹 上 染 频 道 功能 基本 上 一 样 ， 不 同 的 地 方 在 于 推荐 时 从 数据 库 


但 询 的 代码 不 一 样 ， 主 要 核心 的 不 同 部 分 如 下 所 示 : 


<?php 

$sql=mysql_query("select count(*) as total from tb_shangpin where tuijian=1 ",$conn); 
/从 tb_shangpin 数据 表 中 查询 出 tuijian=1 的 商品 

$info=mysql_fetch_array($sq]); 

$total=$info[total]; 

if($total==0) 





{ 
echo "本 站 暂 无 推荐 产品 !"; 
} 
else 
{ 


?> 
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enero 执 门 产品 频道 

单 击 导航 条 中 的 “热门 产品 
门 的 丙 品 。 

Gd) 首先 ， 完 成 静态 页 面 的 设计 ， 该 页面 完成 后 的 效果 如 图 9-39 所 示 。 


四 C:\Apache\htdocs\shop\showhot. php (XHTML) 





”链接 到 页 面 showhot.php， 该 页 面 主要 是 显示 数据 库 中 热 


HIRED top.php left menu.php bottom. php 





图 9-39 热门 产品 的 静态 页 面 效 果 


(20 热门 产品 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 
<?php 
$sql=mysql_query("select * from tb_shangpin order by cishu desc limit 0,10",$conn); 
// 从 tb. shangpin 数据 表 中 查询 出 10 条 的 热门 产品 
$info2mysgql fetch, array($sqL); 
if(Sinfo--false) 
{ 
echo "本 站 和 暂 无 热门 产品 !"; 
j 
else 


{ 
do 





i 


2» 





905 产品 分 类 频道 


单 击 导航 条 中 的 “热门 产品 
同 的 商品 。 


(o 首先 ， 完 成 静态 页 面 的 设计 ， 访 页面 完 成 后 的 效 末 如 图 9-40 所 示 。 


”链接 到 页 面 showfenlei.php， 访 页面 按 商品 的 分 类 显示 不 
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\PHP 网 上 购物 系统 前 台 
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D Internet 
9-40 分 关 的 静态 页 面 效 末 
(20 分 类 的 功能 主要 核心 不 同 部 分 如 下 所 示 : 

<?php 

if($ GET[id]2-"") 

{ 

$sql=mysql_query("select * from tb_type order by id desc limit 0,1",$conn); 

// 从 tb type 数据 表 中 查询 出 所 有 的 商品 分 类 


$info-mysgql fetch, array($sql); 
$id-Sinfo[id]; 





j 


else 
{ 
$id=$_GET[id]; 
j 
$sql12mysgql. query("select * from tb type where id-".S$id."",$ conn); 
$infol2mysgql fetch array(S$sgl1); 


$sql2mysql query('select count(*) as total from tb shangpin where typeid-"".$id." order by 
addtime desc ",$conn); 


$info-mysql fetch  array(S$sql); 
S$total-Sinfo[total]; 
if($total==0) 

{ 


echo "<div align='center> 本 站 暂 无 该 类 产品 !</div>"; 








else 





一 般 的 大 型 网 站 都 没有 搜索 功能 ， 在 首页 中 要 设置 商品 搜索 功能 。 输 入 搜索 的 商品 名 
称 ， 单 击 搜 索 按钮 后 ， 要 打开 的 页 耐 束 是 这 个 商品 搜索 结果 页 面 serchorderphp。 
(1)〉 由 上 面 的 功能 分 析出 发 ， 设 计 好 的 丙 品 搜索 结果 页 面 如 图 9-41 所 示 。 


5 C: NApache\htdocs\shop\serchorder. php (XHTML) -0x 


conn. php  top.php left_menu. php bottom. php 





简体 中 交 (GB2312) — 





9-41 产品 搜索 结果 页 面 


(2) 相关 的 程序 代码 分 析 如 下 : 


<?php 
$jdcz=$_POST[jdcz]; 
$name-$ POST[name]; 
$mh-$ POST[mh]; 
$dx-$ POST[dx]; 
if($dx=="1"){ 
$dx=">"; 

} 

elseif($dx=="-1"){ 

$dx-2"«"; 
} 

else{ 

$dx="="; 
} 
$jg=intval($_POST[jg]); 
$Ib-$ POSTY[Ib]; 

if($jdcz!=""){ 




















PIT CEES 


$sql=mysql_query ("select * from tb shangpin where mingcheng like '%".$name."%' order by addtime 
desc", $conn);//144) 2S 44 EAE] tb. shangpin 数据 表 
j 


else 

| D 
if($mh=="1"){ 

$sql=mysql_query("select * from tb shangpin where huiyuanjia $dx".$jg." and typelid=".$lb.” and 
mingcheng like '%".$name."%'",$conn); 

]/ 按 会 员 价 查 询 tb. shangpin 数据 表 

else{ 

$sql2mysql query("select * from tb shangpin where huiyuanjia $dx".$jg." and typeid-"".$Ib." and 


nt 


mingcheng = "".$name.""",$conn); 
j 
j 
$info2mysql fetch, array(S$sql); 
if(Sinfo--false)( 
echo "<script language-'javascript »alert( Z&» Pf J52S [D P^ im !);history.go(-1);/script? "; 
j 
else( 
2> 
«table width="530" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#CCCCCC"> 
«tr bgcolor="#FOFOFO"> 
«td width='"92" heightz"25"» «div align="center" style="color: 4990000" » 44 f «/div» «/td» 
«td widthz"83"» «div align="center" style="color: 4990000" » m fH «/div» «/td» 
«td widthz"62"» «div align="center" style="color: 4990000" » 1H </div></td> 
«td widthz"62"» «div align="center" style="color: 4990000" » 4 fà ffr «/div» «/td» 
«td widthz"161"» «div align="center" style="color: 4990000"» 上 市 时 间 </div></td> 
«td widthz"48"*» «div align="center" style="color: #FFFFFF"> <span class="style1"></span> </div></td> 
«td width="42"><div align="center" style="color: 4990000" > f&F«/div» </td> 
</tr> 
<?php 
do( 
2» 
«tr bgcolorZ 4 FFFFFF"*» 
«td height2"25"*» «div align="center" > «?php echo $info[mingcheng];2></div></td> 
«td height2"25"*» «div alignz"center"» «?php echo Sinfo[pinpai ];?» </div> </td> 
«td height2"25"» «div align-"center"» «?php echo Sinfo[shichangjia];?» X/div^ </td> 
«td heightz2"25"» «div alignz"center"» «?php echo Sinfo[huiyuanjia];?» </div></td> 
«td height2"25"*» «div align="center" > «?php echo S$info[addtime];?» </div></td> 
<td height2"25"»«div align-"center'»«a href-"lookinfo.php?id-«?php echo $info[id]:?>"> fr 看 
X/a» </div> </td> 
«td heightz"25"»«div align="center"><a href="addgouwuche.php?id=<?php echo $info[id];?>"> 购 物 
</a> </div></td> 
</tr> 
<?php 
}while($info=mysql_fetch_array($sq1)); 









EE B8 a5 5 


S HET 





j 


2» 
</table></td> 
</tr> 

</table> 


到 这 里 ， 就 完成 了 与 商品 相关 动态 页面 的 设计 ， 可 以 实现 网 站 产品 的 前 台 展 示 和 订购 
的 功能 。 





Section 


9.7 ”网 站 的 结算 功能 


网 站 的 核心 技术 ， 就 在 于 产品 的 展示 与 网 上 订购 、 结 算 功能 ， 在 网 站 建设 中 这 部 分 知识 
统称 为 “购物 车 系统 ”。 购 物 车 最 实用 的 功能 就 是 可 进行 产品 结算 ， 通 过 这 个 功能 ， 用 户 在 
选择 了 自己 喜欢 的 产品 后 ， 可 以 通过 网 站 确认 所 需要 的 产品 ， 输 入 联系 方式 ， 提 交 后 写 入 数 
据 库 ， 方 便 网 站 管理 员 进 行 售后 服务 ， 这 也 就 是 购物 车 的 主要 功能 。 


*NAES 订单 的 统计 


addgouwuche.php 页 面 在 前 面 的 代码 中 经 常用 到 ， 束 是 单 击 “购买 ”图 标 按钮 后 ， 需 要 调用 
的 页 面 ， 主 要 是 实现 统计 订单 数量 的 功能 页 面 。 该 页 面 完全 是 PHP 代码 ， 如 图 9-42 所 示 。 
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9-42  addgouwuche.php 页 面 的 设计 


代码 分 析 如 下 : 


<?php 
session start(); 
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include("conn/conn.php"); 
ifí$ SESSION[username]--2" )( 
echo "<script>alert( 请 和 完 登录 后 购物 !");history.back(;</script>"; 
exit; 
}/ 判 断 是 否 已 经 登录 
$id=strval($_GET[id]); 
$sql=mysql_query("select * from tb shangpin where id='".$id."",$conn); 








$info2mysql fetch, array(Ssql); 
if(Sinfo[shuliang]«-0)( 
echo "&script»alert(Z A imi OCGA 56 !);history.back(); «/script? "; 
exit; 
HM/ 判 断 是 否 还 有 产品 
$array=explode("@",$_SESSION[producelist]): 
for($i=0;$i<count($array)-1;$i++){ 
if($array[$i]==$id){ 
echo "<gscript>alert(' 该 商品 已 经 在 您 的 购物 车 中 !);history.backO:;</script>";/ 判 断 是 合 重 复 购 买 


exit; 














} 
$_SESSION[producelist]=$_SESSION[producelist].$id."@"; 


$_SESSION[quatity]=$_SESSION[quatity]."1 @"; 
header("location:gouwuche.php");// 实 现 统 计 累 加 的 功能 并 进行 转 问 
d» 


说 明 : 

session 是 在 PHP 编程 技术 中 ， 占 有 非常 重要 份量 的 函数 。 由 于 网 页 是 一 种 无 状态 的 链 
接 程 序 ， 因 此 无 法 得 知 用 户 的 浏览 状态 。 必 须 通 过 session 变量 记录 用 户 的 有 关 信 息 ， 供 用 
户 再 次 以 此 身份 对 服务 器 提出 要 求 时 做 出 确认 。 


清空 订 曲 


在 购物 车 订购 过 程 中 ， 通 过 单 击 “删除 ”或 “清空 购物 车 ”文字 链接 ， 能 够 调用 
removegwc.php 页 面 ， 通 过 里 面 的 命令 清空 购物 车 中 的 数据 统计 ， 设 计 的 PHP 代码 如 图 9-43 
所 示 。 

清除 订单 的 代码 如 下 : 


<?php 

session start(); 

$id-$ GET[id]; 

$arraysp-explode(" 9 ",$ SESSION[producelist]); 

$Sarrayslzexplode(" 9 ",$ SESSION[quatity]); 

for($120;$i«count(Sarraysp);$i--4-) ( 
if(Sarraysp[$i]--$1d)( 


"M, 


$arraysp[$i]=""; 
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9-43 removegwc.php Ji [ftl 


"tt, 


$arraysl[$i]=""; 
j 
j 
$ SESSION[producelist]-implode(" Q ",Sarraysp); 
$ SESSION[quatity |-implode(" Q ",Sarraysl); 
header("location:gouwuche.php"); 
ro: 








通过 上 面 的 命令 可 以 清空 购物 车 里 的 订单 ， 并 返回 gouwuche.php 重 痢 进行 订购 。 


Is 购物 车 信息 


用 户 登 录 后 选择 商品 放 入 购物 车， 单 击 首页 上 的 “去 收银 合 ” 文 学 链接 ， 则 打开 订单 用 户 信 息 
确认 页 面 gouwusuan.php， 在 该 页 面 中 需要 输入 收 贷 人 的 详细 信息 ， 设 置 的 结 末 如 图 9-44 所 不。 
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9-44 订单 确认 页 面 
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| 生成 订单 
单 击 “提交 订单 ”按钮 后 ， 则 调用 savedd.php 页 面 。 该 页 面 的 功能 是 把 订单 写 入 数据 c 
库 后 返回 gouwusuan.php iig, Hd n: ' 


<?php 
session start(); 








include("conn/conn.php"); 


min 


$sql=mysql_query("select * from tb user where name-"".$ SESSION[username].""",$conn); 
$info2mysgl fetch, array($sql); 
$dingdanhao-date(" Y mjHis").Sinfo[id]; 
$spc-$ SESSION[producelist]; 

$slc= $ SESSION[quatity]; 
$shouhuoren-$ POST[name2]; 

$sex-$ POST[sex]; 

$dizhi-$. POST[dz]; 

$youbian-$ POST[yb]; 

$tel-$ POST[tel]; 

$email-$ POST[email]; 

$shff=$ POST[shff]; 

$zfff-$ POST[zfff]; 

if(trim($_ POST[lyp--"")( 


"M, 
, 


$Sleaveword- 


} 
else{ 
$leaveword-$ POSTI[ly]; 

} 

$xiadanren=$_SESSION[username]; 

$time=date("Y-m-j H:i:s"); 

$zt=" 未 作 任何 处 理 "; 

$total=$ SESSION[total]; 

mysql query('insert into tb dingdan(dingdanhao,spc,slc,shouhuoren,sex,dizhi,youbian,tel,email,shff, 
Zfff,leaveword,time,xiadanren,zttotal) values ($dingdanhao', $spc','$slc', Sshouhuoren', $sex',' $dizhi',' $youbian', 
'Stel','Semail','Sshff','Szfff,'Sleaveword','Stime', $xiadanren','$zt','Stotal')",Sconn); 

header("location:gouwusuan.php?dingdanhao-S$dingdanhao"); 
2» 


| 订单 查询 ) 


用 户 在 购物 的 时 候 ， 还 需要 知道 自己 在 近期 一 共 购 买 了 多 少 商 品 。 单 击 导航 条 上 的 “ 订 
单 查询 ”命令 ， 打 开 查 询 输入 的 页 面 finddd.php， 在 查询 文本 域 中 输入 客户 的 订单 编号 或 者 
下 订单 人 姓名 ， 都 可 以 查 到 订单 的 处 理 情况 ， 方 便 与 网 站 管理 员 的 沟通 。 订 单 查 询 功 能 和 首 
页 上 的 商品 搜索 功能 设计 方法 是 一 样 的 ， 需 要 在 输入 的 查询 页 面 设置 好 连接 库 的 连接 ， 设 置 
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查询 输入 文本 域 ， 建 并 查询 命令 。 具 体 的 设计 分 析 同 前 面 的 搜索 功能 模块 设计 相同 ， 完 成 的 
效果 如 图 9-45 所 示 。 
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图 9-45 订单 查询 页 面 效 果 


通过 本 草 的 介绍 ， 整 个 购物 系统 网 站 前 台 的 动态 功能 的 核心 部 分 痢 已 经 介绍 完 ， 其 他 一 
些小 功能 页 面 这 里 惑 不 做 具体 的 介绍 ， 用 户 在 使 用 时 ， 可 以 根据 目 己 的 需求 对 网 站 进行 一 定 
的 完善 和 更 改 ， 达 到 目 己 的 使 用 要 求 。 























c NE ga PHuPIOVIAEUSGTE 


一 个 完善 的 网 上 购物 系统 不 仅 要 提供 给 用 户 注册 、 购 物 的 功能 ， 它 还 要 提供 给 网 站 所 有 
者 一 个 功能 齐全 的 后 合 管理 功能 ， 例 如 ， 网 站 所 有 者 登录 后 合 即 可 进行 发 布 新 公告 、 会 员 注 
册 管 理 、 回 复 留 言 、 商 品 维护 ， 以 及 订单 的 管理 。 本 章 主要 介绍 使 用 PHP 进行 网 上 购物 系 
统 后 台 开 发 的 方法 。 








MATIE A 


本 草 主要 掌握 以 下 知识 点 : 


O HARRA RA AR 
(7 后 台 登 录 的 商品 管理 功能 
(7 RARAP EHAE 
(7 后 台 的 订单 管理 功能 
(7 后 人 台 的 信息 管理 功能 
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后 台 的 架构 设计 


购物 车 后 台 管 理 系统 是 整个 网 站 建设 的 难点 ， 它 包括 了 几乎 所 有 的 利用 PHP 处 理 技术 ， 实 
例 的 后 合 主要 要 实现 “商品 管理 ^“ 用 户 管理 “订单 管理 ^“ 信 息 管 理 ”4 大 功能 模块 。 和 网 
站 前 台 的 制作 方法 一 样 ， 在 进行 具体 的 功能 开发 之 前 ， 肯 和 完 要 进行 一 个 后 台 的 需求 整体 规划 。 


M 后 台 整体 规划 


本 实例 将 所 有 制作 的 后 台 管 理 页 面 放置 在 admin 文件 夹 下 ， 和 单独 设计 一 个 网 站 一 样 ， 
需要 建立 一 些 音 用 的 文件 夹 ， 如 用 于 连接 数据 库 的 文件 夹 conn、 用 于 放置 网 页 样式 表 的 文件 
F css， 放 置 图 片 的 文件 夹 imnages， 以 及 用 于 放置 上 传 产品 图 片 的 文件 夹 upimages。 设 计 完 
成 的 整体 文件 夹 及 文件 如 图 10-1 所 示 。 
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$5.2 4 天 的 电脑 
10-1 网 站 后 台 文 件 结构 
mE V N Z —^ 
对 需要 设计 的 页 面 功能 分 析 如 表 10-1 所 示 。 
表 10-1 购物 系统 后 台 页 面 功能 分 析 
网 站 后 台 文 件 主要 功能 
addgonggao.php 增加 新 公告 的 页 面 
addgoods.php 增加 商品 信息 的 页 面 
addleibie.php 增加 商品 类 别 的 页 面 
admingonggao.php 增加 商品 公告 的 页 面 
changeadmin.php 管理 员 信息 变更 页 面 
changegoods.php 商品 信息 变更 页 面 
changeleaveword.php 会 员 留 言 变 更 页 面 
chkadmin.php 管理 员 登 录 验 证 页 面 











网 站 后 台 文 件 
conn/conn.php 
default.php 
deleted.php 
deletefxhw.php 
deletegonggao.php 
deletelb.php 
deleteleaveword.php 
deletepingjia.php 
deleteuser.php 
dongjieuser.php 
editgonggao.php 
editgoods.php 
editleaveword.php 
editpinglun.php 
edituser.php 
finddd.php 
function.php 
index.php 
left.php 
lookdd.php 
lookleaveword.php 
lookpinglun.php 
lookuserinfo.php 
orderdd.php 
saveaddleibie.php 
savechangeadmin.php 
savechangegoods.php 
saveeditgonggao.php 
savenewgonggao.php 
savenewgoods.php 
saveorder.php 
showdd.php 
showleibie.php 


top.php 


从 上 和 面 的 分 析 统 计 看 到 该 网 站 后 


ISTF A fn]. 


登录 管 
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主要 功能 
数据 库 连 接 文件 页 面 


后 合 登 录 后 的 首页 E 
删除 订单 的 页 面 


VE 








删除 商品 评论 页 面 
删除 用 户 信息 页 面 
冻结 用 户 处 理 页 面 
编辑 公告 内 容 页 面 
编辑 商品 信息 页 面 
编辑 用 户 留 言 页 面 
编辑 用 户 评 论 页 面 
编辑 用 户 信息 页 面 
订单 查询 页 面 
调用 的 常用 函数 
后 从 用 户 登 录 
展开 式 树 状 导 航 条 
查看 订单 页 面 
RAH AA RM 
查看 用 户 评论 页 面 
但 看 用 户 信 息 页 面 
执行 订单 页 面 
保存 新 增 商 品 大 类 页 面 
保存 用 户 信 息 变 更 页 面 
保存 经 修改 商品 信息 
保存 经 修改 公告 内 容 
保存 新 增 公 告 信息 
保存 新 增 公 告 信息 
保存 执行 订单 页 面 
打印 订单 的 功能 页 面 
商品 大 类 显示 页 面 
台 管 理 的 顶部 文件 

















台 总 共 由 42 个 页 面 组 成 ， 从 开发 的 难 易 度 来 看 并 不 比 








后 台 的 功能 开发 和 网 站 的 前 台 功 能 开发 并 个 大 一 样 ， 前 台 除 了 功能 的 需求 之 外 ， 还 十 
讲究 更 多 的 网 页 布局 即 网 站 的 美工 设计 ， 后 台 的 开发 则 主要 重视 功能 的 需求 开发 ， 而 网 页 





















7PHP-^ 





工 可 以 放 到 其 次 ， 因 为 使 用 后 台 的 丈 古 网 站 所 有 者 那么 一 两 个 人 。 本 小 节 将 介绍 网 站 后 台 从 
登录 到 可 实现 的 定理 具体 有 哪些 流程 ， 以 方便 读者 更 容易 了 解 后 面 小 市 的 内 容 。 

CD 对 于 网 站 所 有 者 需要 登录 后 台 进 行 网 上 购物 系统 的 管理 ， 由 于 涉及 很 多 商业 机 密 ， 
所 以 需要 设计 登录 用 户 确 认 页 面 ， 通 过 和 输入 唯一 的 用 户 名 和 密 码 来 登录 后 侣 进行 管理 。 本 网 
上 购物 系统 为 了 方便 使 用 ， 只 需要 在 首页 用 户 系 统 中 直接 输 入 “用 户 名 ”(admin) fI "E 


但 ”(admin)， 登 录 的 地 址 为 : http://127.0.0.1/shop/admin/login.php， 如 图 10-2 所 示 。 














3 http://127. 0. 0. 1/shop/adain/ login. php 一 1Ccrusro 
Xo) Wo EFEM RA IAM WRho00 
OsSB-O-i|9iauo Par (EX € 2- 


HE OO E) tp //127 0 0 1/ shop admin/ login php 


SH: eeeec! 








图 10-2 后 台 管 理 登 录 页 面 





(2) 单 击 “ 登 录 ” 按 钮 即 可 以 登录 后 台 的 首页 进行 全 方位 的 管理 ， 如 网 10-3 所 示 。 


Hon | #272 
H-u-| sun | EARNE) watw | 
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10-3 “后台 管理 主 界面 





(3) 单 击 左边 树 状 管 理 菜单 中 的 “商品 管理 ”， 可 以 展开 包含 “增加 商品 入 “修改 商 
品 和 “类 别管 理 ^“ 添 加 类 别 ”4 个 功能 荣 单 项 ， 通 过 这 4 个 功能 ， 主 要 实现 商品 的 添加 、 
修改 管理 。 如 图 10-4 所 示 为 增加 商品 页 面 。 
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10-4 增加 商品 页 面 





(40 如 果 想 实现 对 用 户 的 害 理 ， 可 以 单 击 “ 用 户 管理 ”展开 式 亲 单 ， 里 而 包括 了 “会 员 
管理 人 “留言 管理 ”， 以 及 “更 改 管理 员 ”3 个 菜单 项 ， 在 这 3 个 功能 中 ， 后 台 管 理 者 不 但 可 
以 实现 对 注册 会 员 的 删除 管理 ， 还 可 以 实现 相应 留言 的 删除 管理 ， 对 于 后 台 登 录 的 admin 4 
份 也 可 以 进行 变更 。 如 几 10-5 所 示 为 后 台 管 理 者 变更 页 面 。 
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图 10-5 后 台 管 理 者 变更 页 面 








(50 订单 管理 是 购物 系统 后 台 管理 的 核心 部 分 ， 单 击 “ 订 单 管理 ”展开 式 末 单项 ， 可 以 
看 到 包括 了 “编辑 订单 ” "n “AWIE” WARE. KPRI FUSE SCOHUBU tU PW 
单 后 与 管理 员 进 行 交 互 ， 管 理 员 需 要 及 时 处 理 订 单 ， 并 进行 发 货 方 要 完成 的 购物 交易 的 环 
"He. 28451] HI D TRU AUI E] s Bra. 















PHP 





x"o wu «queo «emo IrAm Wwmoo 
ost- O- 9G PER 5A 6 2-23 
BE O0 AE aee //7327:0 0. U she eimi do Fon. phe -wo cxawowr ~v EJHA US Gindi Ù 


mot 


XSSMEX. 

















10-6 编辑 订单 页 面 


(6) 单 击 “信息 管理 ”展开 式 菜 单 ， 其 中 包括 了 “管理 公告 “发 布 公告 ”以 及 “管理 
评价 ”3 个 功能 。 通 过 这 3 个 功能 ， 外 PT E^ pod sh E BE SEE P Id. e E ELE T n 
评论 的 编辑 修改 功能 ， 如 图 10-7 所 示 。 
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107 ”管理 公告 页 面 


上 述 的 后 台 管 理 系统 从 登录 到 各 功能 的 管理 页 面 来 看 ， 后 人 台 管 理 功能 非常 流畅 ， 能 够 捉 
供 非 常 便利 的 网 站 管理 后 台 前 提 是 需要 网 站 设计 者 与 管理 员 沟 通 到 位 ， 问 清 需求 后 ， 方 可 规 
划 出 实用 的 网 站 后 台 。 


"USES 后 台 登 录 的 设计 


一 般 后 台 管 理 员 在 进行 后 台 管 理 时 都 需要 先进 行 身 份 验证 。 实 例 用 于 登录 的 页 面 如 
图 10-8 所 示 ， 在 单 击 “ 登 录 ” 按 钮 后 ， 确 认 后 人 台 登 录 管 理 身 份 的 动态 文件 为 chkadmin.php。 


























QL4Dreamweaver 动态 网 站 建设 从 入 门 到 精通 





g D B * = i3 z B i 
osos ` : =. -" €» 9 E EG IE! 









【PHP 网 上 购物 系统 后 台 开 





四 C: \Apacheihtdocs\shopiadminilogin. php -0x 


管理 员 痘 录 


font. css 
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图 10-8 后 台 管 理 员 登录 静态 效果 


(1) 该 页 面 制作 比较 简单 ， 主 要 的 功能 代码 如 下 : 


<script language-" JavaScript"> 





function chkinput(form)( 
if(form.name.value--"")( 

alert(" 请 输入 用 户 名 !"); 
form.name.select(); 
return(false); 

j 

if(form.pwd.value--"")( 
alert( i548] NH] J m R3 1"); 


form.pwd.select(); 


return(false); 
} 
return(true); 

}]/ 单 击 登 录 按 钮 进行 表单 的 验证 
</script> 


<form name-"form1" method="post" action="chkadmin.php" onSubmit="return chkinput(this)">// 通 过 
验证 后 ， 转 到 chkadmin.php 进行 判断 


(2) chkadmin.php 是 判断 管理 员 吴 份 是 否 正 确 的 页 面 ， 使 用 PHP 编写 的 程序 如 下 : 


<?php 
class chkinput{ 
var $name; 
var $pwd; 
function chkinput($x,$y) 
{ 
$this->name=$x; 
$this->pwd=$y; 
} 


function checkinput() 


{ 









PHP 


include("conn/conn.php"); 


$sgl2mysql. query("select * from tb admin where name=".$this->name."",$conn);// 从 数据 表 tb. admin 
调 出 数据 

$info=mysql_fetch_array($sq]); 

if($info==false) 


{ 
echo "<script language='javascript'>alert(' 不 存在 此 管理 员 ! );history.back(); «/script^ "; 
exit; 
]/ 如 果 不 存 在 ， 则 显示 为 “不 存在 此 管理 员 ” 
else 
{ 


if($info[pwd]==$this->pwd){ 
header("location:default.php"); 
}/ 如 果 正 确 ， 则 登录 default.php W H 


else 
echo "<script language=javascript>alert( 密 但 输入 错误 ! );history.backO;</script> "; 
exit; 
j 


$obj2new chkinput(trim($ POST[name ),md5(trim($ POST[pwd]))); 
$obj-^»checkinput(); 


?> 





O| 树 状 菜单 的 设计 


后 人 台 管 理 的 导航 全 单 是 一 个 树 状 的 展开 式 荣 单 ， 分 为 二 级 某 单 ， 在 单 击 一 级 某 单 时 可 以 
实现 二 级 菜单 的 展开 和 合并 的 操作 ， 在 Dreamweaver 中 设计 的 样式 如 图 10-9 所 示 。 





b C: XÀApachekhtdocshshopkadminkleft. php - 口 X 
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Ps font. css 
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10-9 WASTE 
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而 实现 动态 的 展开 和 合并 是 使 用 JavaScript 实现 的 ， 核 心 的 代码 如 下 : 


<script ljanguage= JavaScript > 


function openspgl(O( 
if(document.all.spgl.style.displayz-"none")[ > | 


document.all.spgl.style.display= 
document.all.d 1 .src="images/point3. gif"; 
j 
else( 
document.all.spgl.style.displayz"none"; 
document.all.d1.src-"images/pointl.gif"; 


j 


j 
function openyhgl()[ 
ifí(document.all.yhgl.style.display2-"none")( 
document.all.yhgl.style.display-z""; 
document.all.d2.src-2"images/point3.gif"; 
j 
else{ 
document.all.yhgl.style.display= none ; 


document.all.d2.src="images/point1.g1f"; 


j 


j 


function openddgl()1 
ifí(document.all.ddgl.style.display2-"none")( 
document.all.ddgl.style.display-z""; 
document.all.d3.srcz"images/point3.gif"; 
j 
else{ 
document.all.ddgl.style.display="none"; 


document.all.d3.src="images/point1.g1f"; 


j 


j 


function opengggl(){ 
ifí(document.all.ggegl.style.display2-"none")( 
document.all.gggl.style.displayz""; 
document.all.d4.src-"images/point3.gif"; 
} 
else{ 
document.all.gggl.style.display="none"; 


document.all.d4.src="images/point1.gif"; 


j 
j 


</script> 
PIRR EAH TAA, wen up ARRAPA A, Bom 
Pd x5 BB tr EH. 
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根据 需求 ， 商 品 管理 功能 页 面包 括 了 增加 商品 Caddgoods.php). fU Ceditgoods.php)s 
2S JI E Cshowleibie.php). WINA] Caddleibie.php) 4 个 功能 页 面 。 本 小 和 残 介 绍 这 几 个 
前 品 管理 功能 页 面 程序 实现 方法 。 








在 前 台 展 示 的 所 有 产品 都 是 从 后 台 进 行商 品 发 布 的 ， 供 商品 发 布 的 学 段 要 与 数据 库 中 保 
存 商品 的 设计 宰 段 一 一 对 应 。 实 例 所 设计 的 增加 商品 静态 页 面 addgoods.php 效果 如 图 10-10 
所 示 。 


T) C: XApacheXht docsshopiadminkaddgoods. php SEA 





aT ma FI FI FI FI E I I I RII I Po 0 0 0 n n n no no n no no no no no no no n n n n n n n ex CX CX CX CX CX AR ex E 





ome me me mi mi mi mi mi me mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi R PU PI mi PII FI mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi mi m me m m mom 
body> Kr) 769 x 394v 8 K / 1 $5 WAPE 2312) 


10-10 增加 商品 的 静态 页 面 效 果 
(1 ) addgoods.php 的 程序 核心 代码 如 下 : 


<script language=" JavaScript"> 
function chkinput(form) 
if(form.mingcheng.value=="") 
alert(" 请 输入 商品 名 称 !"); 
form.mingcheng.select(); 
return(false); 
j 
if(form.huiyuanjia.value2-"") 
{ 
alert(" 请 输入 商品 会 员 价 !"); 
form.huiyuanjia.select(); 
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省 | 二 请 汉 PHP 网 上 购物 系统 后 台 开 发 








return(false); 
j 
if(form.shichangjia.value-z"") 
{ i 
alert(" 请 输入 商品 市 场 价 !"); Ə 
form.shichangjia.select(); 
return(false); 
j 
if(form.dengji.value--"") 
{ 


alert(" 请 输入 商品 等 级 !"); 
form.dengji.select(); 
return(false); 
} 
if(form.pinpai.value=="") 
{ 
alert(" 请 输入 商品 品牌 !"); 
form.pinpai.select(); 





return(false); 


j 


if(form.xinghao.value--"") 
{ 
alert(" 请 输入 商品 型 号 !"); 
form.xinghao.select(); 
return(false); 


j 


if(form.shuliang.value-z"") 


{ 
alert(" WFA F8] mA"); 
form.shuliang.select(); 





return(false); 


j 


if(form.jianjie.value—- 


{ 


"tt 


alert(" 请 输入 商品 简介!"); 
form.jianjie.select(); 
return(false); 


j 


return(true); 


</script>// 进 行 表 单 验 证 
«form name="form1" enctype="multipart/form-data" method="post" action="savenewgoods.php" 
onSubmit="return chkinput(this)">// 验 证 后 提交 savenewgoods.php 页 面 进行 处 理 


(2) savenewgoods.php 是 实现 将 发 布 的 商品 信息 保存 到 数据 库 的 文件 ， 代 人 码 如 下 : 


<?php 
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include("conn/conn.php"); 








if(is numeric($ POST[shichangjia])--false || is numeric($ POST[huiyuanjia])—-false) 


{ 
echo "<script>alert(' 价 格 只 能 为 数字 ! ";history.backO;«/script^ "; 
exit; 
} 
if(is numeric($ POST[shuliang])==false) 
{ 
echo "<script>alert( 数 量 只 能 为 数学 ! ';history.back();</script>"; 
exit; 
} 
$mingcheng-$ POST[mingcheng]; 
$nian=$ POST[nian]; 
$yue-$ POST[yue]; 
$ri=$ POST[ri]; 
$shichangjia-$ POST[shichangjia]; 
$huiyuanjia-$ POST[huiyuanjia]; 
$typeid-$ POST[typeid]; 
$dengji-$ POST[dengji]; 
$xinghao-$ POST[xinghao]; 
$pinpai-$ POST[pinpai]; 
$tuijian-$ POSTY[tuijian]; 
$shuliang-$  POST[shuliang]; 
$upfile-$ POST[upfile]; 
if(ceil(($huiyuanjia/$shichangjia)* 100)«280) 
{ 
$tejia=1; 
} 
else 
{ 
$tejia=0; 
} 
function getname($exname)( 
$dir = "upimages/";// 列 出 产品 图 片 的 上 传 目 录 
$i=1; 
if(lis_dir($dir)){ 
mkdir($dir,0777); 
} 
while(true){ 
if(lis_file($dir.$1.".".$exname)){ 
$name=$1i.".".$exname:; 
break; 





j 
$i++; 
j 


return $dir.$name; 
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} 
$exname=strtolower(substr($_FILES['upfile'][name'],(strrpos($_FILES['upfile'][name'],.)+1))); 
$uploadfile = getname(Sexname); 


move. uploaded file($ FILES['upfile']|'tmp name'], Suploadfile); NI 
if(trim($ FILES['upfile']| name']!2"")) © 
{ "m 
$uploadfile-"admin/".$uploadfile; * 
} 
else 
{ 
$uploadfile=""; 
} 


$jianjie=$_POST[jianjie]; 


$addtime=$nian."-".$yue."-".$ri; 

mysql_query("insert into tb_shangpin(mingcheng,jianjie,addtime,dengji,xinghao,tupian,typeid,shichangjia, 
huiyuanjia,pinpai,tuijian,shuliang,cishu)values('$mingcheng','$jianjie', '$addtime','$dengji','$xinghao','$upl 
oadfile','$typeid','$shichangjia','$huiyuanjia','$pinpai','$tuijian','$shuliang','0')",$conn); 

echo "<script>alert(' R ii " .$mingcheng." 75372] !);window.location.href='addgoods.php';</script>"; 
?>/ 上传 成 功 转向 addgoods.php 页 面 


上 述 PHP 的 程序 编写 中 ， 核 心 在 于 产品 图 片 的 上 传 功能 。 
eR 修改 商品 功能 


在 商品 发 布 后 ， 如 果 发 现 发 布 的 商品 信息 有 错误 ， 可 以 通过 单 击 “ 修 改 商品 ”功能 来 进 
行商 品 信息 的 调整 。 在 后 台中 单 击 “ 修 改 商 品 ” 打开 的 是 editgoods.php WH. 























(1) 使 用 Dreamweaver 制作 的 静态 页 面 效 果 如 图 10-11 所 示 。 


四 C:\Apache\htdocs\shop\admin\editEoods. php = CX 


CALD font.css conn. php 
g 











<body> (RIQ 100$  ~|T45 x 2987 8 K / 1 秒 | 简体 中 文 喇 2512) 








图 10-11 修改 商品 静态 页 面 效 采 


(2) 在 该 页 面 中 可 以 单 击 “ 复 选 ” 复 选 按钮 ， 再 单 击 “ 删 除 选项 ”按钮 实现 商品 删除 的 
操作 ， 链 接 到 deletefxhw.php 进行 删除 操作 。deletefxhw.php 是 从 数据 库 中 删除 该 商品 信息 ， 
使 用 的 代码 如 下 : 


<?php 
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include("conn/conn.php"); 
while(list($name,$value)zeach($ POST)) 
{ 
$sql=mysql_query("select tupian from tb_shangpin where id="".$value.""",$conn); 
$info=mysql_fetch_array($sql); 
if($info[tupian]!="") 
{ 
@unlink(substr($info[tupian],6,(strlen($info[tupian])-6))); 
j 
$sgli2mysql. query("select * from tb dingdan ",$conn); 
while(Sinfol-mysql fetch array($sql1)) 
{ $idl-Sinfol [id]; 
$array-explode(" Q ",Sinfol[spc]); 
for($120;Si«count(Sarray);$i--4-) ( 
if(Sarray[$i1]--$ value) 


{ 
mysql_query("delete from tb dingdan where 1d="".$1d1."",$conn); 
j 
j 
j 
mysql query("delete from tb shangpin where id- ".$value.""",Sconn); 
mysql query("delete from tb pingjia where spid="".$value.""",$conn); 
j 
header("location:editgoods.php"); 
?> 





(3) 通过 单 击 “ 更 改 ” 文 字 链 接 能 打开 changegoods.php 页 面 进行 商品 的 信息 变更 ， 该 





页 面 设计 的 样式 和 添加 产品 时 的 样式 是 一 样 的 ， 如 图 10-12 所 示 。 


b C: SApache*ht docsSshop*adminkchangegoods. php -0x 


€i font.css conn. php 





EA AA B. 








> 
body? Kp?) (k]é9 Q 100€ v745 x 430v 13 K / 1 秒 | 简体 中 文 (652512) 














图 10-12 商品 的 信息 变更 页 面 











(4) 在 编辑 商品 信息 之 后 ， 单 击 “ 更 改 ” 按 钮 提交 表单 到 savechangegoods.php 页 面 进 
行 数据 库 的 更 新 操作 ， 核 心 代码 如 下 : 
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<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 

<?php 

include("conn/conn.php"); 

$mingcheng-$ POST[mingcheng]; 
$nian=$ POST[nian]; © 
$yue-$ POST[yue]; 

$ri=$ POST[ri]; 

$shichangjia-$ POST[shichangjia]; 

$huiyuanjia-$ POST[huiyuanjia]; 

$typeid-$ POST[typeid]; 

$dengji-$. POST[dengji]; 

$xinghao-$ POST[xinghao]; 

$pinpai-$  POST[pinpai]; 

$tuijian-$. POST[tuijian]; 

$shuliang-$ POST[shuliang]; 

//Supfile-$ POST[upfile]; 


if(ceil(($huiyuanjia/Sshichangjia)* 100) «280) 
{ 
$tejia=1; 
j 
else 
{ 
$tejia=0; 
j 
if(Supfile!-"") 
{ 
$sql=mysql_query("select * from tb_shangpin where 1d=".$_GETI[id]."",$conn); 
$info2mysgql fetch, array($sql); 
(à unlink(substr(S$info[tupian],6,(strlen(Sinfo[tupian])-6))); 
j 


function getname($exname)( 
$dir 2 "upimages/"; 
$i=1; 
if(lis_dir($dir)){ 
mkdir($dir,0777); 


while(true)( 
if('is file($dir.$1.".".Sexname))( 
$name-$i.".".Sexname; 
break; 

} 


$i++; 
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return $dir.$name; 


S$exname-strtolower(substr($ FILES ['upfile']| name'],(strrpos($. FILES['upfile'][ name'],'.)--1))); 
$uploadfile = getname(Sexname); 

move. uploaded file($ FILES['upfile']|'tmp name'], Suploadfile); 

$uploadfile-"admin/".$uploadfile; 

$jianjgie-$ POST[jianjie]; 

$addtime-$nian."-".$yue."-".$ri; 

mysql. query(" update tb shangpin set 
mingcheng-' $mingcheng'jianjie-' $jianjie',addtime-'$addtime',dengji-'$dengji',xinghao-' $xinghao',tupia 
n-'$uploadfile',typeid- Stypeid',shichangjia-'$shichangjia',huiyuanjia- $huiyuanjia',pinpai- $Spinpai',tuiji 
an-'$tuijian',shuliang-' $shuliang' where id-".$. GET[id]." ",Sconn); 
echo "«script»alert( Ñ ia ".$mingcheng. f P VJ] V); history .back0;;«/script» "; 
T> 


更 新 数据 库 主要 应 用 到 了 update 这 个 数据 库 更 新 命令 。 


10.2.3 MBR n1) RE ) 


商品 的 类 别提 供 了 删除 功能 ， 通 过 单 击 “操作 ” 复 选 按钮 再 单 击 “ 删 除 选 项 ” 即 可 以 将 
类 别 从 数据 库 中 删除 。 访 功能 首页 为 showleibie.php。 

(1) 使 用 Dreamweaver 设计 的 该 页 面 的 静态 效果 如 图 10-13 所 示 。 访 页面 主要 实现 从 类 
列 的 数据 表 中 得 询 出 相应 的 数据 绑 定 到 该 页 面 。 























T C: pacheWhtdoesVshop Va dninVshowl eibi e. php SAE 
v 
CHRED font.css conn. php Y 











<body> (R]® Q 100% v480 x 188v 4 K / 1 秒 APE Gz 








图 10-13 MRJ R r 


(2) 单 击 选择 相应 的 类 列 复 选 按 钮 ， 再 日 击 “ 删 除 选 项 ”， PEKAR] deletelb.php 动态 
页 面 进 行 删 除 。 在 删除 时 ， 要 把 相关 联 的 商品 信息 也 一 并 删除 ， 即 通过 商品 的 ID 同时 删除 
tb type 和 tb_shangpin。 实 现 删 除 类 别 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
while(list($name,$value)=each($_POST)){ 
mysql_query("delete from tb type where id=".$value.”"",$conn);// 删 除 类 别 
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mysql_query("delete from tb shangpin where id=".$value."",$conn);// 删 除 类 别 下 的 商品 
} 
header("location:showleibie.php");// 删 除 成 功 ， 则 转 问 showleibie.php 页 面 

2» 


添加 类 别 功能 es 


电子 商务 网 站 的 商品 是 多 种 多 样 的 ， 在 后 全 要 设置 商品 分 类 的 功能 。 在 实际 的 网 站 开发 
中 经 名 有 一 级 分 类 、 二 级 分 类 ， 甚 全 三 级 分 类 都 有 ， 这 些 还 涉及 来 单 的 二 级 联动 问题 。 本 实 
例 只 建立 了 一 级 分 类 ， 管 理 员 可 以 在 后 台 直 接 添 加 一 级 的 分 类 ， 谎 加 类别 功能 的 主页 面 是 
addleibie.php. 

(1) 使 用 Dreamweaver 设计 addleibie.php 页 面 的 静态 效果 如 图 10-14 所 示 。 














Ts] C: pa chehhtdocs*shophadminiaddleibie. php -Dx 


增加 类 别 
Bem: — 





ky Qj 100€ — [543 x dde 3 K / 1 $0. Hipi Giz) 





图 10-14 IMAI PETRI ER SCA 





(20 在 单 击 “ 增 加 ” 投 钮 的 时 候 ， 要 先进 行 表单 验证 ， 再 提交 到 saveaddleibie.php 页 
面 ， 进 行 插 入 数据 库 的 操作 。 该 页面 的 代码 如 下 : 


$leibie=$_POST[leibie]; 
include("conn/conn.php"); 
$sql2mysql query("'select * from tb type where typename-"" $leibie.""",Sconn); 
$info2mysql fetch, array(Ssql); 
if(Sinfo!-false)( 

echo" &script»alert( 122351] 52$ 1f 1E V );window.location.href-'addleibie.php'; «/script^ "; 
exit; 
HM/ 判 断 类 别 是 否 存 在 
mysql query("insert into tb type(typename) values ('Sleibie")",$Sconn); 
echo"&script^alert( Jr PZS VJ] !');window.location.href-'addleibie.php'; «/script^ "; 
S/A 3,4] 48 IH] addleibie.php 


在 编写 的 时 候 要 充分 考虑 到 类 别 是 否 已 经 存在 ， 因 此 需要 加 入 一 个 判断 环节 。 














Section 


qug 用 户 管理 功能 


用 户 管 理 功 能 与 前 人 台 的 用 户 注册 功能 互相 呼应 ， 对 于 一 个 购物 网 站 来 说 ， 一 个 完善 的 用 
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户 管理 系统 一 定 要 有 -一 个 功能 比较 强大 的 用 户 后 台 管理 ， 实 例 中 制作 了 “会 员 管理 “留言 





管理 人 “更 改 管 理 员 ”3 个 菜单 项 ， 本 小 节 陨 介绍 这 几 个 小 功能 的 实现 方法 。 


quem enters 





会 员 的 管理 功能 主要 是 指 能 够 在 后 台 实 现 会 员 的 删除 ， 对 一 些 会 员 能 够 实现 “冻结 ”的 操 
作 ， 保 留 会 员 的 信息 但 苯 止 其 在 前 人 台 进 行 购物 及 发 言 。 会 员 管理 功能 的 首页 为 edituserphp, il 
作 的 详细 步骤 如 下 。 

(1) 使 用 Dreamweaver 设计 的 会 员 管 理 页 面 如 网 10-15 所 示 。 











Ts] C: Màpachesht docssshophadmin'edituser. php -DHx 


ER font.css conn. php 


:本 站 共有 注册 用 户 Ji 位 每 页 显示 Gu) pr e Gu) v/dt gu) vr Hp) 4 « du) Gu) Gu) Guy 


` 
- 
` 
` 


k| Qj 100& 668 x 222 T K / 1 $6 Mpi (GB2312) 








(20 单 击 “ 删 除 ” 复 选 按 钮 ， 再 单 击 “ 删 除 选项 ”时 ， 能 够 提交 表单 到 deleteuserphp 
动态 页 和 面 ， 即 可 实现 会 员 数 据 删 除 的 操作 。 访 页 面 的 程序 如 下 : 


<?php 

include("conn/conn.php"); 

while(list($name,$value)=each($_POST)) 
{ 


mysql_query("delete from tb_user where id=".$value. 











"tt 


,$conn); 
mysql query(" delete from tb pingjia where userid=". $value.""); 


"tt 


mysql query("delete from tb leaveword where userid-".$ value." ",$conn); 


j 
header("location:edituser.php"); 
T> 


注意 : 
在 删除 会 员 的 时 候 ， 同 样 要 注意 删除 数据 库 中 tb user. tb pingjia. tb leaveword 这 3 个 
数据 表 中 所 有 关联 的 数据 ， 删 除 成 功 后 要 返回 会 员 管 理 主页 面 。 


(3) 在 单 击 “ 答 看 详细 ”链接 后 ， 将 打开 对 用 户 信息 “冻结 ”和 “解冻 ”的 页 面 looku 
serinfo.php， 访 得 看 用 户 信息 的 页 面 如 网 10-16 所 示 。 
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四 C:\ipache\htdocs\shop\admin\lookuserinfo. php -Bx 


"SS font. ess conn. php 


M] 


u-» Fam 


eus 


本 se 
2 
”人 

。 Ji 


n= Tam 





body? Kn T01 x 291v 5 K / 1 秒 | 简体 中 文 582312) 
10-16. 会 看 用 户 信 息 页 面 


编写 实现 对 用 户 信 息 “ 冻 结 ” 和 “解冻 ”的 程序 其 实 非常 人 镜 单 ， 只 要 赋值 为 0 或 者 1 来 
区 分 古人 盏 冻结 ， 在 俘 询 会 员 信息 的 时 候 残 能 够 按 俘 询 是 0 或 者 是 1 来 给 会 员 权 限 。 代 码 如 下 : 


<?php 
$sql=mysql_query("select * from tb_user where id=".$id."",$conn); 











$info=mysql_fetch_array($sql); 
if($info[dongjie]==0) 
{ 
echo "冻结 该 用 户 "; 
} 


else 


{ 
echo "解除 冻结 "; 
} 


?> 


10.3.2 


当 会 员 在 购物 时 过 到 问题 ， 可 以 直接 通过 留言 功能 和 管理 员 进 行 沟通 ， 后 台 管 理 员 要 及 
时 浏览 会 员 的 留言 并 进行 相应 的 处 理 ， 对 于 一 n 的 留言 可 以 直接 删除 。 用 于 留言 管理 的 
页 面 古 lookleaveword.php. 

C1) 制作 的 留言 处 理 页 面 lookleaveword.php 效果 如 图 10-17 所 示 。 


T C: Apachexht docsVshophadminllookleaveword. php - 口 X 











HIRED font. css conn. php function. php 





R] Q 100%  , T60x 2257 T K / 1 秒 简体 中 交 (6B2312) — 


10-17 留言 处 理 页 面 
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(2) 该 页 面 主要 是 从 数据 库 中 查询 所 有 的 留言 并 显示 在 网 页 中 ， 在 单 击 “ 删 除 ” 复 选 按 
钮 ， 再 单 击 “ 删 除 选 项 ”时 ， 提 交 表 单 信息 至 deleteleaveword.php 页 面 进行 删除 数据 的 操 
作 。 实 现 删 除 的 代码 如 下 : 


<?php 

include("conn/conn.php"); 
while(list($name,$value)=each($_POST)) 
{ 


mysql_query("delete from tb_leaveword where id= 


j 


header("location:lookleaveword.php"); 
?>// 删 除 成 功 返 回 lookleaveword.php 


ORE 更 改 管理 员 功 能 


网 站 开发 者 在 开发 时 一 般 使 用 的 用 户 名 和 密码 都 是 admin， 在 提交 给 网 站 管理 员 时 ， 为 
了 安全 起 见 ， 管 理 员 要 能 够 实现 后 合 管理 员 的 用 户 名 和 蜜 但 的 修改 。 实 现 该 功能 的 页 面 是 
changeadmin.php. 

CG) 制作 的 更 改 管理 员 页 面 changeadmin.php 的 效果 如 图 10-18 所 示 。 


111 nt 


.$value.""",$conn); 














b C:XApache'ht docs*shop*adminkchangeadmin. php - 0X 








body> (k]éy Q 100$  ~v|T51 x 1534 5 K / 1# pX (682312) 


图 10-18 网 站 管理 员 后 台 修 改 页 面 


(20 输入 新 旧 管 理 员 的 用 户 名 和 密码 ， 再 单 击 “ 更 改 ” 按 钮 ， 可 以 提交 表单 进行 验证 ， 
然后 提交 到 savechangeadmin.php 进行 数据 更 新 的 操作 。 实 现 的 代码 如 下 : 


<?php 
$n0=$_POST[n0]; 
$n1=$_POST[n1]; 
$p0=md5($_POST[p0]); 
$pl=trim($_POST[p1); 


include("conn/conn.php"); 








$sql=mysql_query("select * from tb admin where name='".$n0."",$conn); 
$info2mysql fetch, array(Ssql); 
if(Sinfo--false) 
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echo "«script»alert( Af 4E 5 H] J^? );history.back(;«/script» "; 
exit; 


j 


else © 
l v 


if(Sinfo[pwd]--$p0) 


{ 
if($n1!="") 
{ 
mysql_query("update tb admin set name='".$n1.""where id=".$info[id]." ",$conn); 
j 
if($pl fm) 
{ 
$pl=md5($p1); 
mysql query("update tb admin set pwd='".$p1."" where id=".$infoļ[id]."",$conn); 
j 
j 
else 
{ 
echo "<script>alert(' JR 2 144i ACE VA); history.back(); «/script? "; 
exit; 
j 
j 
echo "«script»alert(' E MI ');history.back();X/script? "; 
2» 





该 程序 首先 对 管理 员 的 用 户 名 进行 验证 ， 判 断 正 确 后 才 进 行 数 据 更 新 ， 并 显示 更 新 


订单 管理 功能 














订单 管理 功能 是 购物 网 站 的 重点 ， 对 于 网 站 管理 员 而 言 ， 一 定 要 及 时 登录 后 人 台 对 订单 进 








行 管理 并 及 时 发 货 。 实 例 在 登录 后 台 时 把 订单 管理 的 功能 放 到 了 玖 认 打 开 的 页 面 ， 主 要 包 丘 
了 “编辑 订单 ”和 “查询 订单 ”2 个 小 功能 。 下 面 就 分 别 做 介绍 。 








编辑 订 蛙 功能 


所 谓 的 编辑 订单 是 指 管理 员 在 登录 后 台 后 ， 对 会 员 提 交 的 订单 进行 “已 收 蒜 ”“ 已 发 




















货 ”“ 已 收 货 ” 等 验证 ， 同 时 要 及 时 打印 出 网 上 订单 并 提交 给 公司 进行 发 货 处 理 。 编 辑 订 单 
的 主页 是 lookdd.php。 

(1) 设计 的 lookdd.php 页 面 的 效果 如 图 10-19 所 示 。 该 页 面 只 有 简单 的 订单 信息 功能 ， 
只 要 从 数据 库 中 查询 订单 进行 显示 即 可 。 
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四 C:\Apache\htdocs\shop\admin\lookdd. php LX 


8 T HB « « HDD HD HM oi Bg REER | 





750 x 263« 8 K / 1 秒 | 简体 中 文 (5B2312) 


10-19 ”编辑 订单 页 面 





(2) 设计 的 第 二 步 陨 是 实现 单 击 “ 奉 看 ”按钮 时 ， 能 调 出 订单 的 详细 内 容 showdd.php 


和 面 ， 并 能 进行 打印 。 在 网 上 浏览 的 效果 如 图 10-20 所 示 。 





73 nttp://127.0.0.1 — 商品 订单 -~ Nicrosoft Internet Explorer m ES 


订单 号 : 2011062801112144 | 打印 预览 | | 打印 


刘 小 小 
: “北京 朝阳 戏 桥 12 号 
101121 RB 话 : 13800138000 
designemü153. com 
普通 平邮 支付 方式 : 建设 银行 汇款 
汇款 时 注 明 您 的 订单 号 ?汇款 后 请 及 时 联系 我 们 ， 





8D Internet 





10-20 ”订单 详细 内 容 页 面 


showdd.php 页 面 中 调用 函数 实现 打印 的 功能 ， 具 体 的 代码 如 下 : 


<html> 

<head> 

«meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
«title» rj mii] H.«/title» 

<link rel="stylesheet" type="text/css" hrefz"css/font.css"» 
<style type="text/css"> 

<l-- 

@media print{ 

div {display:none } 

j 

.Style3 (color: #990000} 

2s. 

</style> 











省 | 二 请 汉 PHP 网 上 购物 系统 后 台 开 发 





</head> 
<?php 
include("conn/conn.php"); 


$id=$_GET[id]; | 
$sql2mysql query('select * from tb dingdan where id='".$id."'"",$conn); c 
$info2mysql fetch array($sql); | 
$spc-S$info[spc]; 
$slc-Sinfo[slc]; 
$arraysp-explode(" Q ",$spc); 
$arraysl=explode(" @",$slc); 
2» 
«body topmargin-z"0" leftmargin="0" bottommargin= "0 > 
<p>&nbsp;</p> 
<table width="600" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr align="center" bgcolor="#FFCF60"> 
«td height="20" colspan="2" bgcolor="#0099FF"> 简 总 订单 </td> 
</tr> 
<tr> 
«td width="448" height="20"> 订 单 写 : <?php echo $info[dingdanhao];?></td> 
«td width="152"><div align="right"> 
<script> 
function prn()[ 
document.all. WebBrowserl.ExecWB(7,1); 
j 
</script> /实现 打印 预览 的 功能 
<object  ID2'WebBrowserl' WIDTH=0  HEIGHT-0 | CLASSID-'CLSID:8856F961-340A- 
11D0-A96B-00C04FD705A2^» </object> 
«input type="button" valuez"$T Eft v" classz"buttoncss" onClicke"prn()"» &nbsp; 
«input type="button" value-"1] ED" class-"buttoncss" onClick-"window.print()"» «/div» «/td»//S: B 1T 
印 的 功能 


</tr> 
<tr> 
«td height="20" colspan="2"> 商 品 列 表 ( 如 下 ): </td> 
</tr> 
</table> 


«table width="500" height="60" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td bgcolor="#666666"><table width="500" border="0" align="center" cellpadding="0" 
cellspacing="1"> 
<tr bgcolor="#0099FF"> 
<td width="153" height="20"> 商 品名 称 </td> 
«td width="80"> 市 场 价 </td> 
«td width="80"> 会 员 价 </td> 
«td width="80"> 数 量 </td> 
«td width="101"> 小 计 </td> 
</tr> 
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<?php 
$total=0; 
for($i=0;$i<count($arraysp)-1;$i++){ 
if($arraysp[$1]!=""){ 
$sqgl12mysgql. query("select * from tb_shangpin where id= 


111 nt 


.Sarraysp[$i].""", Sconn); 
$infol-mysql fetch, array($sql1); 
$total-$total---Sarraysl[$1]*Sinfol [huiyuanjia]; 
2 
«tr bgcolor="#FFFFFF"> 
«td height="20"><?php echo S$infol [mingcheng];?» «/td» 
«td heightz"20"* «?php echo S$infol [shichangjia];?» </td> 
«td heightz"20"* «?php echo S$infol [huiryuanjia];?» </td> 
«td heightz"20"* «?php echo S$arraysl[$1i];?» «/td» 
«td heightz"20"* «?php echo S$arraysl[$1] *Sinfol [huiyuanjia];?» </td> 
</tr> 
<?php 
j 
} 
2> 
<tr bgcolor="#FFFFFF"> 
<td height="20" colspan="5"> 
总 计 费 用 :<?php echo $total;?> 
</td> 
</tr> 
</table> </td> 
</tr> 
</table> 
«table width="460" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
«td width="81" height="20"> 下 单 人 : </td> 
«td colspan="3"><?php echo Sinfo[xiadanren];?» </td> 
</tr> 
<tr> 
«td height="20"> 收 贷 人 : </td> 
<td height="20" colspan="3"><?php echo $info[shouhuoren];?> </td> 
</tr> 
<tr> 
«td height="20"> 收 货 人 地 址 : </td> 
«td height="20" colspanz"3"» «?php echo $info[dizhi];?> </td> 
</tr> 
<tr> 
«td height="20"> 邮 &nbsp;&nbsp; 编 : </td> 
«td width="145" height="20"><?php echo $info[youbian];? ></td> 
«td width="66"> 电 &nbsp;&nbsp; 话 : </td> 
«td widthz" 158"» «?php echo $info[tel];?></td> 
</tr> 
<tr> 












cc 840€ QUNETECLLEZ: 





«td heightz" 20" * E-mail: «/td* 
«td height" 20" «?php echo Sinfo[email|;?» </td> 
«td heightz"20"» &nbsp;«/td» 
«td heightz"20"» &nbsp;«/td» 
</tr> 
<tr> 
«td height="20"> 送 货 方式 : </td> 
<td height="20"><?php echo $info[shff];?></td> 
«td height="20"> 文 付 方式 : </td> 
«td height="20"><?php echo $info[zfff];?> </td> 
</tr> 
<tr> 
«td height="20" colspan="4"><span class-"inputcssnull"» 7| 3I] 33: HH A85 HP] V] Hoy 1 TE UR ie Jc 
时 联系 我 们 ! «/span» «/td» 
</tr> 
<tr> 
«td height="20">&nbsp; </td> 
«td height="20"><div align="center"><input type="button" onClick="window.close()”value=" 关 
闭 窗口 " class="buttoncss"></div></td> 
«td height="20"> 创 建 时 间 : </td> 
«td height="20"><?php echo $info[time];?> </td> 
</tr> 
</table> 
</body> 
</html> 


(3) 要 实现 订单 的 网 上 处 理 ， 单 击 “ 执 行 ”按钮 即 可 以 打开 orderdd.php 页 面 ， 进 行 订单 
的 处 理 。 其 中 包括 了 “已 收 款 入 “已 发 货 和 “已 收 货 ”3 个 复 选 按钮 ， 对 其 进行 相应 的 处 理 ， 
如 图 10-21 所 示 。 


T C: XÀpachehht docskshopkadminkorderdd. php -Dx 





Pm font.css conn. php 





R| Q 1008 4 TE5 x 434v 98 K / 1 秒 简体 中 交 (6B2312) 


10-21 执行 订单 页 面 
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(4) 单 击 “修改 ”按钮 即 提 交 表 到 saveorder.php 进行 修改 数据 的 保存 ， 有 具体 的 代码 如 下 : 


<?php 
$ysk=$_POST[ysk]."&nbsp;"; 
$yfh=$_POST[yfh]." &nbsp;"; 
$ysh=$_POST[ysh]."&nbsp;"; 
$zt=""; 
if($ysk!="&nbsp;"){ 
$zt.=$ysk; 
j 
if(Syfh!2"&nbsp;")( 
$zt.-$yfh; 
j 
if($ysh!="&nbsp;"){ 
$zt.=$ysh; 
j 
if((Sysk--"&nbsp;")&&(Syfh--"&nbsp;")&&(Sysh--"&nbsp;"))( 
echo "<script>alert(' 请 选择 处 理 状 态 !"):history.back();</script>"; 
exit; 
j 


include("conn/conn.php"); 


11111 


$sql3=mysql_query("select * from tb_dingdan where id='".$_GET[id]."",$conn); 
$info32mysql fetch array($sq13); 
if(trim($info3[zt]) 2" Zk f EFE fn] Rb E") ( 


$sql2mysql query("select * from tb dingdan where id='".$_GET[id]. 


nt 


,$conn); 
$info=mysql_fetch_array($sql); 

$array=explode(" 9 ",Sinfo[spc]); 

$arraysl-explode("  " Sinfo[slc]); 


for($i-0;$i«count(Sarray);$i--4-)( 
$id-$array [$1]; 
$num-$arraysl[$i]; 


111 "nt. ' 


mysql query("update tb shangpin set cishu-cishu- ".$num." ,shuliang-shuliang-"".$num." 
where 1d="".$id.""",$conn); 
j 
j 
mysql query("update tb dingdan set zt-'".Szt." where id2".$ GET[id].""",Sconn); 
header("location:lookdd.php"); 


?> 


通过 上 述 4 个 步骤 的 设计 ， 后 台 的 订单 编辑 功能 即 开发 完成 . 
”查询 订单 功能 


在 网 站 运营 一 段 时 间 后 ， 网 上 的 订单 会 越 来 越 多 ， 也 经 营 会 遇 到 会 员 会 询 订单 的 事情 ， 
网 站 管理 员 同 样 也 需要 一 个 订单 后 人 台 奏 询 功 能 ， 才 能 方便 地 找到 相应 的 订单 。 实 例 奋 询 和 显 


n 






























Jude $105 GD 于 二 到 








"NER E Re HI vr. BI finddd.php. 
CDD 制作 的 finddd.php 页 面 效果 如 图 10722 所 示 。 


四 C: XÀpache*htdocskshopNadminkfinddd. php mir 


"hat font ess conn. php 





body? pi R] Q 100$  . T36 x 249v 7K71 秒 | 简体 中 文 682312) 


10-22 ”查询 订单 页 面 


(2) 核心 程序 如 下 : 


<html> 
<head> 
«meta http-equiv="Content-Type" content-"text/html; charset=gb2312"> 
«title» 1] ££. rif «/title» 
<link rel="stylesheet" type="text/css" hrefz"css/font.css"» 
</head> 
<?php 
include("conn/conn.php"); 
?> 
<body topmargin="0" leftmargin="0" bottommargin="0"> 
<p>&nbsp;</p> 
<table width="550" border="0" align="center" cellpadding="0" cellspacing="0"> 


<tr> 
«td height="20" bgcolor="#0099FF"><div align="center" style="color: #FFFFFF"> 订 单 查 
询 </div></td> 
</tr> 
<tr> 


<td heightz"50"  bgcolorz'2555555"»«table width="550"  height2"50" border= 0" 
align="center" cellpadding-"0" cellspacing= 1] > 
«tr? 
«td bgcolor="#FFFFFF"> 
«table width" 550" heightz" 50" borderz"0" align="center" cellpadding="0" cellspacingz"0"» 
<script language-"javascript"» 
function chkinput3(form) 


if((form.username.value--" ")&&(form.ddh.value--"")) 


{ 
alert(" 请 输入 下 订单 人 或 订单 写 "); 


form.username.select(); 
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return(false); 


j 


return(true); 


</script> 
<form name="form3" method="post" action="finddd.php" onSubmit="return 
chkinput3( this)"> 
<tr> 
<td height="25"><div align="center"> 下 订单 人 姓名 :<input type="text" name= 
"username" class-"inputcss" size-"25" > 
订单 号 :<input type="text" name-"ddh" size="25" class-"inputcss" ></div> 
</td> 
</tr> 
<tr> 
<td height="25"> 
<div align="center"> 
<input type="hidden" value="show_find" name="show_find"> 
<input name-"button" type="submit" class-"buttoncss" id="button" 


value=" fr 找 "> 
</div></td> 
</tr> 
</form> 
</table></td> 
</tr> 
</table></td> 
</tr> 
</table> 
<table width="550" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td> &nbsp;</td> 
</tr> 
</table> 
<?php 


if($_POST[show_find]!=""){ 
$username-trim($ POST[username]); 
$ddh-trim($ POST[ddh]); 
if(Susername--"")( 
$sgl2mysql query('select * from tb dingdan where dingdanhao="".$ddh."",$conn); 


j 
elseif($ddh--"")( 
$sgl2mysql query('select * from tb dingdan where xiadanren='".$username."",$conn); 
j 
else{ 


111 


$sqgl2mysql query("'select * from tb dingdan where xiadanren='".$username."'and 


dingdanhao=".$ddh."",$conn); 
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} 
$info2mysql fetch, array($sql); 
if(Sinfo--false)( 
echo "<div algin='center> 对 不 起 ,没有 得 找到 该 订单 !</div>"; M 
/ D 
else { 
1> 
<table width="550" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
«td height="20" bgcolor="#0099FF"><div align="center" style="color: #FFFFFF"> 查 询 结 
果 </div></td> 
</tr> 
<tr> 
<td heightz"50"  bgcolorz'2555555"»«table width="550" height="50" border="0" 
align="center" cellpaddingz"0" cellspacing="1"> 
<tr> 
<td width="77" height="25" bgcolor="#FFFFFF"><div align="center"> i| 单 5 
</div></td> 
«td width="77" bgcolor="#FFFFFF"><div align="center"> F £P? </div></td> 
«td width="77" bgcolor="#FFFFFF"> <div align="center"> i] $$ A </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align="center"> 47 4i yF </div></td> 
<td width="77" bgcolor="#FFFFFF"><div align2"center"» ] 3X 7j 3X </div></td> 
«td widthz"77" bgcolorz" 4FFFFFF"» «div align="center"> 1 5X 7j 3X </div></td> 
«td width='"77" bgcolor="#FFFFFF"><div align="center"> 1] Fs «/div» «/td» 
</tr> 
<?php 
do( 
jo 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[dingdanhao];?» </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[xiadanren];?></div> </td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[shouhuoren];? ></div> </td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[total];2» </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[zfff];?» </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[shff];?> </div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info 
[zt];?» </div></td> 
</tr> 
<?php 
)while(Sinfo2mysgql. fetch. array ($sql)); 









PHP 





?> 


</table></td> 
</tr> 
</table> 
<?php 





In = a E 管理 功能 日 上 


信息 管理 功能 是 指 在 网 站 后 台 实 现 新 闻 、 用 户 的 商品 评价 等 相关 的 管理 操作 ， 本 实例 制 
作 了 管理 公告 、 发 布 公告 、 管 理 评价 3 个 功能 ， 通 过 这 3 个 功能 ， 能 够 实现 整个 网 站 的 即时 
公告 发 布 、 公 告 修改 ， 以 及 商品 评论 的 编辑 修改 功能 。 











管理 公告 功能 


管理 公告 功能 是 指 可 以 在 后 台 对 发 布 的 公告 进行 修改 和 删除 。 管 理 公 告 的 页 面 为 
admingonggao.php. 
CI) 制作 的 管理 公告 页 面 admingonggao.php 效果 如 图 10-23 所 示 。 


四 C: AApachexht docssshop*adminiadmingonggao. php -0X 


HS font.css conn. php 





[RS Q 1008 vv|753 x 268. TK / 14 füffchir(oB2312) — - 


10-23 ”管理 公告 页 面 


(2) 单 击 “ 选 择 ” 复 选 按 钮 ， 再 单 击 “删除 所 选 ” 按 钮 ， 可 以 提交 表单 到 deletegonggao.php， 
进行 删除 公告 的 操作 ， 代 码 如 下 : 


<?php 
include("conn/conn.php"); 
while(list($name,$value)=each($_POST)) 


{ 
mysql_query("delete from tb_gonggao where id= 


"wf nt 


.$value.""",$conn); 
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j 
header("location:admingonggao.php"); 
2» 


(3) 单 击 “ 人 修改” 文字 链接 ， 可 以 打开 editgonggao.php 页 面 进行 公告 的 编辑 操作 ， 访 页 
面 如 图 10-24 所 示 。 


T) C: XÀpache^ht docsshop*adminkedi t gonggao. php = 0x 


Hau font. css conn. php 





z > 
body? Kr) (R| Qj 1008  « T40 x 268v 4 K / 1 d^ 简体 中 交 (6B2312) — - 


10-24 修改 公告 页 面 


(4) 和 输入 修改 的 公告 主题 和 公告 内 容 ， 再 单 击 “ 更 改 ” 按 钮 ， 可 以 提交 表单 到 saveeditgonggao. 
Php， 进 行内 容 的 更 新 操作 ， 更 新 的 代码 如 下 : 


<?php 
$title-$ POST[title]; 
$content-$ POST[content]; 
include("conn/conn.php"); 


ntt 


,$conn); 


mysql query("update tb_gonggao set title='$title',content='$content' where id="".$_POSTI[id]. 
echo "<script>alert( 公 告 修改 成 功 !);history.backO;</Script> "; 
5 





10.5.2 


用 于 添加 新 的 公告 的 页 面 是 addgonggao.php， 实 现 的 方法 束 是 采集 公告 的 字段 进行 数据 
的 插入 操作 。 本 小 节 就 介绍 添加 新 公告 的 具体 方法 。 
(1) 添加 新 公告 页 面 addgonggao.php 如 图 10-25 所 示 。 


四 C:\Apache\htdocs\shop\admin\addEonEEao. php - 口 X 


HIED font. css 








All > 
[R| 江 Ql100% v|722 x 270v 4 K / 1 秒 MAPE 2312) — - 


10-25 ”添加 新 公告 页 面 
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(20 录入 完 主 题 和 内 容 ， 单 击 “ 添 加 ”按钮 ， 可 以 提交 表单 进行 验证 ， 并 提交 到 
savenewgonggao.php 负面， 进行 新 公告 的 保存 操作 。 实 现 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
$title-$ POST[title]; 
$content=$ POST[content]; 
$time-date("Y -m-j"); 
mysql query("insert into tb. gonggao (title,content,time) values ('Stitle','Scontent','Stime")",Sconn); 
echo "&script^alert( s A RJK ');history.back();«/script? "; 
2 








后 人 台 的 最 后 一 个 功能 是 管理 评价 功能 ， 通 过 管理 可 以 将 商品 的 一 些 负 面 信 息 进 行 删除 操 
作 。 管 理 评价 功能 的 页 面 是 editpinglun.php， 人 制作 的 方法 如 下 。 
(1) 编辑 用 户 评价 页 面 editpinglun.php 的 效果 如 图 10-26 所 示 。 





四 | C: \Apache\htdocs\shopadminieditpinglun. php = 0X 


a PME 


ky Q 1008 v TAT x 2009 T K / 1 秒 简体 中 六 (GB2312) 








10-26 ”编辑 用 户 评价 页 面 


(2) 通过 单 击 “ 查 看 ”文字 链接 ， 能 打开 Windows 窗口 显示 评价 的 详细 内 容 ， 实 现 的 
mE 


<?php 
include("conn/conn.php"); 
$sql=mysql_query("select count(*) as total from tb_pingjia ",$conn); 
$info-mysgl fetch, array($sql); 
$total-Sinfo[total]; 
if($total==0) 
echo "本 站 和 暂 无 用 户 友 表 评 论 !"; 
} 


else 


{ 


?> 
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省 | 二 请 汉 PHP 网 上 购物 系统 后 台 开 发 





<script ljanguage= javascrlpt > 
function openpj(id) 


{ 
window.open("lookpinglun.php?id="+id,"newframe","width=500,height=300,top=100,left=200,menubar G 


-no,toolbar-no,location-no,scrollbar-no,status-no"); 


j 


</script> 


(3) 单 击 “ 删 除 ” 复 选 按钮 ， 再 单 击 “ 删 除 选项 ”按钮 ， 可 以 提交 表单 全 删除 评价 的 页 
Ifi] deletepingjia.php， 该 页面 的 代码 如 下 : 


<?php 
include("conn/conn.php"); 
while(list($name,$value)=each($_POST)) 


{ 
$id=$value; 
mysql_query("delete from tb pingjia where id=".$id."",$conn); 


j 
header("location:editpinglun.php"); 
75 


通过 上 述 儿 大 后 合 管理 功能 的 开发 ， 读 者 可 以 发 现 使 用 PHP 进行 网 上 后 合 管理 系统 的 
开发 其 实 并 不 难 。 正 所 谓 “ 磨 思 不 误 砍 烷 工 ”， 在 开发 类 似 的 网 站 时 一 定 要 做 后 台 开 发 前 的 
架构 设计 ， 与 需求 方 沟通 到 位 ， 可 以 轻松 实现 网 站 的 开发 工作 。 
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UG NX 7.5 完全 自学 手册 
书号 : 32379 定价 : 56.00 元 
作者 : 钟 日 铭 等 

本 书 以 UG NX 7.5 中 文 版 软件 为 操作 基 
础 ， 结 合 典 型 范例 循序 渐进 地 介绍 了 该 软件 的 
功能 和 实战 应 用 知识 。 本 书 知识 全 面 、 实 用 ， 


共 分 9 章 ， 内 容 包括 ，UG NX 7.5 入 门 简介 及 基 | 


本 操作 、 草 图 、 空 间 曲 线 与 基准 特征 、 创 建 实 


体 特征 、 特 征 操作 及 编辑 、 曲 面 建 模 、 装 配 设 | 


计 、 工 程 图 设计 、GC 工 具 箱 应 用 与 同步 建 模 。 






AutoCAD 2012 中 文 版 

入 门 。 进 阶 。 精通 第 2 版 
书号 : 34957 E: 52.00 元 
作者 : 钟 日 铭 等 

本 书 以 AutoCAD 2012 中 文 版 为 基础 , 结合 
软件 功能 和 特点 ， 循 序 渐进 地 介绍 了 AutoCAD 
入 门 、 进 阶 与 精通 的 应 用 知识 。 本 书 图 文 并 成 、 
结构 清晰 、 重 点 突出 、 实 例 典型 、 应 用 性 强 ， 


是 一 本 很 好 的 从 入 门 到 精通 的 学 习 教程 ， 适 合 | 
从 事 机械 设 计 、 建 筑 制图 、 电 气 绘图 、 广告 制 | 


作 等 工作 的 专业 技术 人 员 阅 读 。 


UG NX 7. 5 基础 应 用 与 
范例 解析 第 3 版 
书号 : 36423 定价: 59.80 元 
作者 : 李 志 尊 等 


本 书 介 绍 了 利用 UG NX 7.5 进行 实体 建 
模 、 装 配 建 模 、 工 程 制 图 、 运 动 仿真 以 及 有 限 


元 分 析 等 方面 的 内 容 。 本 书 的 写作 结合 了 作者 | 


多 年 来 在 机 械 设计 教学 和 科研 方面 的 经 验 ， 内 
容 选 取 适 当 ， 范 例 具 有 典型 的 代表 性 ， 叙 述 简 
Zo BARH, TAR. 
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SolidWorks 2011 机 械 设计 
完全 实例 教程 

书号 : 36514 定价: 62.00 元 
作者 : 张 忠 将 等 

本 书 紧 密 结合 实际 应 用 ， 以 众多 精彩 的 机 | 
械 设 计 实 例 为 引导 ， 详 细 介绍 了 SolidWorks 从 E 
模型 创建 到 出 工程 图 ， 再 到 模型 分 析 和 仿真 等 外 
的 操作 过 程 。 本 书 实例 涵盖 典型 机 械 零 件 、 输 
送 机 械 、 制 动机 械 、 农 用 机 械 、 紧 固 和 夹具 、 
传动 机 构 和 弹簧 / 控制 装置 等 的 设计 。 














ANSYS 13.0 与 HyperMesh 11.0 
联合 仿真 有 限 元 分 析 

书号 : 37170 E: 49.00 元 
作者 : 贺 李 平 等 

本 书 主 要 讲解 如 何 利 用 HyperMesh11.0 建 f 
立 高 质量 的 有 限 元 模型 ， 再 以 ANSYS13.0 作 为 | 
求解 器 来 解决 各 类 工程 问题 。 全 书 共 20 章 , 包 | 
含 了 Hyper Mesh 有 限 元 网 格 建 模 、ANSYS 单 元 | 
技术 、 装 配 体 连接 技术 、 瞬 态 动力 学 分 析 、 响 | 
应 谱 分 析 和 多 体 刚 .和 柔 系 统 分 析 等 内 容 。 | 


SolidWorks 2011 中 文 版 数字 样机 | 
技术 及 其 应 用 实例 〈 人 入 门 与 提高 ) | 
书号 : 36684 E: 79.80 元 

作者 : 印 会 朋 


本 书 按 “ 数 字样 机 ”和 “数字 样机 技术 ” | 
的 全 新 理念 编著 ， 系 统 讲述 了 SolidWorks 2011 | 
中 文 版 数字 样机 技术 及 其 应 用 实例 。 本 书 适合 | 
广大 从 事 数 字样 机 研发 的 从 业 人 员 阅 读 和 参 | 
考 , 也 可 作为 应 用 型 本 科 院 校 、 职业 技术 学 院 、| 
技师 学 院 和 高 级 技工 学 校 相关 课程 的 教材 或 参 | 
考 书 。 \ 





aries ded é3tvityeipralevitovbredesatavitredtyeioyéttv re 


追逐 App Store 的 脚步 
手机 软件 开发 者 创 富 之 路 


ISBN 978-7-111-35619 -6 定价: 49.00 元 
作者 : 项 有 建 


是 如 何 针对 现代 手机 软件 产品 进行 设计 ;介绍 
了 数字 产品 的 营销 方法 ， 特 别 是 如 何 针对 现代 
手机 软件 产品 进行 营销 的 方法 。 书 中 强调 了 用 
户 需求 以 及 竞争 两 个 设计 视角 , 介绍 了 “平台 辐 
射 原理 ”, 初步 解决 了 如 何 利 用 公式 化 的 方法 用 
平台 推广 产品 的 问题 。 


Windows Phone 7 完美 开发 征程 
ISBN 978-7-111-34043 -0 E: 45.00 元 
作者 : [UR 

本 书 以 全 新 的 Windows Phone 7 手机 应 用 


程序 开发 为 主题 ， 采 用 理论 和 实践 相 结合 的 方 | 
法 ， 由 浅 入 深 地 讲述 了 新 平台 的 基础 架构 、 开 
发 环境 、 图 形 图 像 处 理 、 数 据 访问 、 网 络 通信 
等 知识 点 。 最 后 通过 较为 完整 的 实战 演练 ， 帮 
助 读者 更 快 地 掌握 项 目 开发 的 各 个 技术 要 点 ， 
使 读者 能 够 尽快 投入 到 实际 项 目的 开发 。 


从 实例 走 进 OPhone 世 界 
ISBN 978-7-111-33030 -1 定价: 45.00 元 
作者 : 周 轩 

本 书 从 一 个 开发 者 的 角度 出 发 ， 介 绍 了 
OPhone/Android 系 统 的 基础 知识 和 开发 技巧 ， 
详细 讲解 了 无 线 通 信 、 娱 乐 游 戏 、 移 动 生活 、 
OPhone 特 色 应 用 等 多 种 类 型 程序 的 开发 流程 
和 方法 ; 通过 介绍 系统 上 自 带 源 代码 实例 ， 为 读 
者 提供 参考 资料 和 分 析 素 材 。 环 境 ， 并 配 有 大 
量 插图 和 代码 注释 ， 为 自学 者 提供 了 方便 。 








本 书 介绍 了 如 何 进行 软件 产品 设计 , 特别 | 
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Android 开发 案例 驱动 教程 
ISBN 978-7-111-35004 -0 ”定价 : 69.80 元 
作者 : 关东 升 

本 书 旨 在 帮助 读者 全 面 掌握 Android 开 发 | 
技术 ， 能 够 实际 开发 Android 项 目 。 本 书 全 面 介 | 
绍 了 在 开源 的 手机 平台 Android 操 作 系统 下 的 | 


应 用 程序 开发 技术 ， 包 括 UI、 多 线程 、 数 据 存 | 
储 、 多 媒体 、 云 端 应 用 以 及 通信 应 用 等 方面 。 | 
本 书 采用 案例 驱动 模式 展开 讲解 ， 既 可 作为 高 | 
等 学 校 的 参考 教材 , 也 适合 广大 Android 初 学 者 | 
和 Android 应 用 开发 的 程序 员 参 考 。 | 


ed 


从 灵感 到 实现 一 一 打造 你 

第 一 个 Windows Phone 7. 5 应 用 
ISBN 978-7-111-37452-7 EW: 56.00 元 
作者 : 李 永 伦 | 
本 书 讲述 了 一 个 真实 应 用 的 开发 故事 , 为 | 
你 呈现 一 个 完整 的 开发 过 程 ， 包 括 安装 环境 、 | 
需求 分 析 、 原 型 设计 、 功 能 开发 、 应 用 测试 和 | 


错误 修正 。 本 书包 含 了 详细 的 可 操作 的 步骤 ， 


“手把手 教 你 实现 相关 功能 ， 并 且 留 下 一些 作业 | 


给 你 练 手 , 以 便 巩固 这 节 课 学 到 的 知识 和 技术 。 | 


Qt 开发 Symb ian 应 用 权威 指南 
ISBN 978-7-111-36089 -6 FET: 45.00 元 
作者 : Fitzek 等 译 者 : DevDiv 移动 开发 社区 | 

本 书 主要 是 向 读者 介绍 如 何在 Symbian 上 | 
快速 有 效 地 创建 Qt 应 用 程序 。 全 书 共 分 7 章 , 包 | 
括 开发 入 门 、Qt 概 述 、Qt Mobility APIS、 类 Qt | 
移动 扩展 、 Qt 应 用 程序 和 Symbian 本 地 扩展 、 | 
Qt for Symbian 范 例 。 | 

本 书 可 作为 移动 设备 开发 领域 的 初学 者 和 | 
专业 人 员 的 参考 用 书 ， 也 可 作为 手机 开发 基础 | 
课程 的 教材 。 | 





机 工 出 版 社 . 计算 机 分 社 书 友 会 邀请 
尊敬 的 读者 : 
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